The branch, master has been updated
       via  c6f82b525913856c9b483c8df43e5eecd896203b (commit)
       via  5b6c4287638eb556270cec170e33004af24d7691 (commit)
       via  0844cca1d5e4579b54af7d03509f3f97fac43bdc (commit)
      from  e7f7ed8bf6281ef01aca53ea44acdd4af4c51aa7 (commit)

http://gitweb.samba.org/?p=samba.git;a=shortlog;h=master


- Log -----------------------------------------------------------------
commit c6f82b525913856c9b483c8df43e5eecd896203b
Author: Volker Lendecke <v...@samba.org>
Date:   Fri Feb 13 11:49:17 2009 +0100

    Remove the s4 version of smbspool.c

commit 5b6c4287638eb556270cec170e33004af24d7691
Author: Volker Lendecke <v...@samba.org>
Date:   Fri Feb 13 11:17:42 2009 +0100

    Fix an uninitialized variable, introdued with 4d100f2f

commit 0844cca1d5e4579b54af7d03509f3f97fac43bdc
Author: Volker Lendecke <v...@samba.org>
Date:   Fri Feb 13 10:56:34 2009 +0100

    Replace get_myname() with the talloc version from v3-3-test

-----------------------------------------------------------------------

Summary of changes:
 lib/util/util.c                  |   26 ++--
 lib/util/util.h                  |    4 +-
 source3/client/smbspool.c        |    2 +-
 source3/include/proto.h          |    2 +-
 source3/lib/util.c               |   31 +----
 source3/nmbd/nmbd_processlogon.c |    2 +-
 source3/rpc_client/cli_pipe.c    |    2 +-
 source3/torture/torture.c        |    2 +-
 source3/utils/ntlm_auth.c        |    2 +-
 source4/client/smbspool.c        |  353 --------------------------------------
 source4/param/loadparm.c         |    4 +-
 11 files changed, 22 insertions(+), 408 deletions(-)
 delete mode 100644 source4/client/smbspool.c


Changeset truncated at 500 lines:

diff --git a/lib/util/util.c b/lib/util/util.c
index 40ac7f7..988d8f9 100644
--- a/lib/util/util.c
+++ b/lib/util/util.c
@@ -192,34 +192,30 @@ _PUBLIC_ void msleep(unsigned int t)
 }
 
 /**
- Get my own name, return in malloc'ed storage.
+ Get my own name, return in talloc'ed storage.
 **/
 
-_PUBLIC_ char *get_myname(void)
+_PUBLIC_ char *get_myname(TALLOC_CTX *ctx)
 {
-       char *hostname;
        char *p;
-
-       hostname = (char *)malloc(MAXHOSTNAMELEN+1);
-       *hostname = 0;
+       char hostname[HOST_NAME_MAX];
 
        /* get my host name */
-       if (gethostname(hostname, MAXHOSTNAMELEN+1) == -1) {
+       if (gethostname(hostname, sizeof(hostname)) == -1) {
                DEBUG(0,("gethostname failed\n"));
-               free(hostname);
                return NULL;
-       } 
+       }
 
        /* Ensure null termination. */
-       hostname[MAXHOSTNAMELEN] = '\0';
+       hostname[sizeof(hostname)-1] = '\0';
 
        /* split off any parts after an initial . */
-       p = strchr(hostname, '.');
-
-       if (p != NULL)
+       p = strchr_m(hostname, '.');
+       if (p) {
                *p = 0;
-       
-       return hostname;
+       }
+
+       return talloc_strdup(ctx, hostname);
 }
 
 /**
diff --git a/lib/util/util.h b/lib/util/util.h
index dced557..7873f0e 100644
--- a/lib/util/util.h
+++ b/lib/util/util.h
@@ -536,9 +536,9 @@ _PUBLIC_ int set_blocking(int fd, bool set);
 _PUBLIC_ void msleep(unsigned int t);
 
 /**
- Get my own name, return in malloc'ed storage.
+ Get my own name, return in talloc'ed storage.
 **/
-_PUBLIC_ char* get_myname(void);
+_PUBLIC_ char* get_myname(TALLOC_CTX *mem_ctx);
 
 /**
  Return true if a string could be a pure IP address.
diff --git a/source3/client/smbspool.c b/source3/client/smbspool.c
index 7943cf5..a276353 100644
--- a/source3/client/smbspool.c
+++ b/source3/client/smbspool.c
@@ -485,7 +485,7 @@ smb_connect(const char *workgroup,  /* I - Workgroup */
        /*
          * Get the names and addresses of the client and server...
          */
-       myname = talloc_get_myname(talloc_tos());
+       myname = get_myname(talloc_tos());
        if (!myname) {
                return NULL;
        }
diff --git a/source3/include/proto.h b/source3/include/proto.h
index 7ad063e..3410472 100644
--- a/source3/include/proto.h
+++ b/source3/include/proto.h
@@ -1154,7 +1154,7 @@ void *Realloc(void *p, size_t size, bool 
free_old_on_error);
 void add_to_large_array(TALLOC_CTX *mem_ctx, size_t element_size,
                        void *element, void *_array, uint32 *num_elements,
                        ssize_t *array_size);
-char *talloc_get_myname(TALLOC_CTX *ctx);
+char *get_myname(TALLOC_CTX *ctx);
 char *get_mydnsdomname(TALLOC_CTX *ctx);
 int interpret_protocol(const char *str,int def);
 char *automount_lookup(TALLOC_CTX *ctx, const char *user_name);
diff --git a/source3/lib/util.c b/source3/lib/util.c
index 68d3322..6079e71 100644
--- a/source3/lib/util.c
+++ b/source3/lib/util.c
@@ -1209,35 +1209,6 @@ void add_to_large_array(TALLOC_CTX *mem_ctx, size_t 
element_size,
 }
 
 /****************************************************************************
- Get my own name and IP.
-****************************************************************************/
-
-char *talloc_get_myname(TALLOC_CTX *ctx)
-{
-       char *p;
-       char hostname[HOST_NAME_MAX];
-
-       *hostname = 0;
-
-       /* get my host name */
-       if (gethostname(hostname, sizeof(hostname)) == -1) {
-               DEBUG(0,("gethostname failed\n"));
-               return False;
-       }
-
-       /* Ensure null termination. */
-       hostname[sizeof(hostname)-1] = '\0';
-
-       /* split off any parts after an initial . */
-       p = strchr_m(hostname,'.');
-       if (p) {
-               *p = 0;
-       }
-
-       return talloc_strdup(ctx, hostname);
-}
-
-/****************************************************************************
  Get my own domain name, or "" if we have none.
 ****************************************************************************/
 
@@ -2237,7 +2208,7 @@ char *myhostname(void)
        if (ret == NULL) {
                /* This is cached forever so
                 * use talloc_autofree_context() ctx. */
-               ret = talloc_get_myname(talloc_autofree_context());
+               ret = get_myname(talloc_autofree_context());
        }
        return ret;
 }
diff --git a/source3/nmbd/nmbd_processlogon.c b/source3/nmbd/nmbd_processlogon.c
index a4ef528..59a2ca4 100644
--- a/source3/nmbd/nmbd_processlogon.c
+++ b/source3/nmbd/nmbd_processlogon.c
@@ -442,7 +442,7 @@ reporting %s domain %s 0x%x ntversion=%x lm_nt token=%x 
lm_20 token=%x\n",
                                                ("get_mydnsdomname failed.\n"));
                                                return;
                                        }
-                                       hostname = 
talloc_get_myname(talloc_tos());
+                                       hostname = get_myname(talloc_tos());
                                        if (!hostname) {
                                                DEBUG(2,
                                                ("get_myname failed.\n"));
diff --git a/source3/rpc_client/cli_pipe.c b/source3/rpc_client/cli_pipe.c
index 2841ff0..24dbcb0 100644
--- a/source3/rpc_client/cli_pipe.c
+++ b/source3/rpc_client/cli_pipe.c
@@ -3417,7 +3417,7 @@ NTSTATUS rpc_pipe_open_ncalrpc(TALLOC_CTX *mem_ctx, const 
char *socket_path,
        result->transfer_syntax = ndr_transfer_syntax;
        result->dispatch = cli_do_rpc_ndr;
 
-       result->desthost = talloc_get_myname(result);
+       result->desthost = get_myname(result);
        result->srv_name_slash = talloc_asprintf_strupper_m(
                result, "\\\\%s", result->desthost);
        if ((result->desthost == NULL) || (result->srv_name_slash == NULL)) {
diff --git a/source3/torture/torture.c b/source3/torture/torture.c
index 9cf41d8..db89b05 100644
--- a/source3/torture/torture.c
+++ b/source3/torture/torture.c
@@ -5862,7 +5862,7 @@ static void usage(void)
        *p = 0;
        fstrcpy(share, p+1);
 
-       fstrcpy(myname, talloc_get_myname(talloc_tos()));
+       fstrcpy(myname, get_myname(talloc_tos()));
        if (!*myname) {
                fprintf(stderr, "Failed to get my hostname.\n");
                return 1;
diff --git a/source3/utils/ntlm_auth.c b/source3/utils/ntlm_auth.c
index ab5a743..9bc0c60 100644
--- a/source3/utils/ntlm_auth.c
+++ b/source3/utils/ntlm_auth.c
@@ -523,7 +523,7 @@ static NTSTATUS winbind_pw_check(struct ntlmssp_state 
*ntlmssp_state, DATA_BLOB
 {
        static const char zeros[16] = { 0, };
        NTSTATUS nt_status;
-       char *error_string;
+       char *error_string = NULL;
        uint8 lm_key[8]; 
        uint8 user_sess_key[16]; 
        char *unix_name = NULL;
diff --git a/source4/client/smbspool.c b/source4/client/smbspool.c
deleted file mode 100644
index df867d5..0000000
--- a/source4/client/smbspool.c
+++ /dev/null
@@ -1,353 +0,0 @@
-/* 
-   Unix SMB/CIFS implementation.
-   SMB backend for the Common UNIX Printing System ("CUPS")
-   Copyright 1999 by Easy Software Products
-   Copyright Andrew Tridgell 1994-1998
-   Copyright Andrew Bartlett 2002
-   
-   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 3 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, see <http://www.gnu.org/licenses/>.
-*/
-
-#include "includes.h"
-
-/*
- * Local functions...
- */
-
-static void            list_devices(void);
-static struct smbcli_state     *smb_connect(const char *, const char *, const 
char **, const char *, const char *, const char *);
-static int             smb_print(struct smbcli_state *, char *, FILE *);
-
-
-/*
- * 'main()' - Main entry for SMB backend.
- */
-
- int                           /* O - Exit status */
- main(int  argc,                       /* I - Number of command-line arguments 
*/
-     char *argv[])             /* I - Command-line arguments */
-{
-  int          i;              /* Looping var */
-  int          copies;         /* Number of copies */
-  char         uri[1024],      /* URI */
-               *sep,           /* Pointer to separator */
-               *password;      /* Password */
-  const char   *username,      /* Username */
-               *server,        /* Server name */
-               *printer;       /* Printer name */
-  const char   *workgroup;     /* Workgroup */
-  FILE         *fp;            /* File to print */
-  int          status=0;               /* Status of LPD job */
-  struct smbcli_state *cli;    /* SMB interface */
-  struct loadparm_context *lp_ctx;
-
-  /* we expect the URI in argv[0]. Detect the case where it is in argv[1] and 
cope */
-  if (argc > 2 && strncmp(argv[0],"smb://", 6) && !strncmp(argv[1],"smb://", 
6)) {
-         argv++;
-         argc--;
-  }
-
-  if (argc == 1)
-  {
-   /*
-    * NEW!  In CUPS 1.1 the backends are run with no arguments to list the
-    *       available devices.  These can be devices served by this backend
-    *       or any other backends (i.e. you can have an SNMP backend that
-    *       is only used to enumerate the available network printers... :)
-    */
-
-    list_devices();
-    return (0);
-  }
-
-  if (argc < 6 || argc > 7)
-  {
-    fprintf(stderr, "Usage: %s [DEVICE_URI] job-id user title copies options 
[file]\n",
-            argv[0]);
-    fputs("       The DEVICE_URI environment variable can also contain the\n", 
stderr);
-    fputs("       destination printer:\n", stderr);
-    fputs("\n", stderr);
-    fputs("           smb://[username:passw...@][workgroup/]server/printer\n", 
stderr);
-    return (1);
-  }
-
- /*
-  * If we have 7 arguments, print the file named on the command-line.
-  * Otherwise, print data from stdin...
-  */
-
-  if (argc == 6)
-  {
-   /*
-    * Print from Copy stdin to a temporary file...
-    */
-
-    fp     = stdin;
-    copies = 1;
-  }
-  else if ((fp = fopen(argv[6], "rb")) == NULL)
-  {
-    perror("ERROR: Unable to open print file");
-    return (1);
-  }
-  else
-    copies = atoi(argv[4]);
-
- /*
-  * Find the URI...
-  */
-
-  if (strncmp(argv[0], "smb://", 6) == 0)
-    strncpy(uri, argv[0], sizeof(uri) - 1);
-  else if (getenv("DEVICE_URI") != NULL)
-    strncpy(uri, getenv("DEVICE_URI"), sizeof(uri) - 1);
-  else
-  {
-    fputs("ERROR: No device URI found in argv[0] or DEVICE_URI environment 
variable!\n", stderr);
-    return (1);
-  }
-
-  uri[sizeof(uri) - 1] = '\0';
-
- /*
-  * Extract the destination from the URI...
-  */
-
-  if ((sep = strrchr_m(uri, '@')) != NULL)
-  {
-    username = uri + 6;
-    *sep++ = '\0';
-
-    server = sep;
-
-   /*
-    * Extract password as needed...
-    */
-
-    if ((password = strchr_m(username, ':')) != NULL)
-      *password++ = '\0';
-    else
-      password = "";
-  }
-  else
-  {
-    username = "";
-    password = "";
-    server   = uri + 6;
-  }
-
-  if ((sep = strchr_m(server, '/')) == NULL)
-  {
-    fputs("ERROR: Bad URI - need printer name!\n", stderr);
-    return (1);
-  }
-
-  *sep++ = '\0';
-  printer = sep;
-
-  if ((sep = strchr_m(printer, '/')) != NULL)
-  {
-   /*
-    * Convert to smb://[username:passw...@]workgroup/server/printer...
-    */
-
-    *sep++ = '\0';
-
-    workgroup = server;
-    server    = printer;
-    printer   = sep;
-  }
-  else
-    workgroup = NULL;
-
- /*
-  * Setup the SAMBA server state...
-  */
-
-  setup_logging(argv[0], DEBUG_STDOUT);
-
-  lp_ctx = loadparm_init(talloc_autofree_context());
-
-  if (!lp_load(lp_ctx, dyn_CONFIGFILE)) {
-         fprintf(stderr, "ERROR: Can't load %s - run testparm to debug it\n", 
lp_config_file());
-         return (1);
-  }
-
-  if (workgroup == NULL)
-    workgroup = lp_workgroup(lp_ctx);
-
-  do
-  {
-    if ((cli = smb_connect(workgroup, server, lp_smb_ports(lp_ctx), printer, 
username, password)) == NULL)
-    {
-      if (getenv("CLASS") == NULL)
-      {
-        fprintf(stderr, "ERROR: Unable to connect to SAMBA host, will retry in 
60 seconds...");
-        sleep (60);
-      }
-      else
-      {
-        fprintf(stderr, "ERROR: Unable to connect to SAMBA host, trying next 
printer...");
-        return (1);
-      }
-    }
-  }
-  while (cli == NULL);
-
- /*
-  * Now that we are connected to the server, ignore SIGTERM so that we
-  * can finish out any page data the driver sends (e.g. to eject the
-  * current page...  Only ignore SIGTERM if we are printing data from
-  * stdin (otherwise you can't cancel raw jobs...)
-  */
-
-  if (argc < 7)
-    CatchSignal(SIGTERM, SIG_IGN);
-
- /*
-  * Queue the job...
-  */
-
-  for (i = 0; i < copies; i ++)
-    if ((status = smb_print(cli, argv[3] /* title */, fp)) != 0)
-      break;
-
-  talloc_free(cli);
-
- /*
-  * Return the queue status...
-  */
-
-  return (status);
-}
-
-
-/*
- * 'list_devices()' - List the available printers seen on the network...
- */
-
-static void
-list_devices(void)
-{
- /*
-  * Eventually, search the local workgroup for available hosts and printers.
-  */
-
-  puts("network smb \"Unknown\" \"Windows Printer via SAMBA\"");
-}
-
-
-/*
- * 'smb_connect()' - Return a connection to a server.
- */
-
-static struct smbcli_state *           /* O - SMB connection */
-smb_connect(const char *workgroup,             /* I - Workgroup */
-            const char *server,                /* I - Server */
-           const char **ports,           /* I - Ports */
-            const char *share,         /* I - Printer */
-            const char *username,              /* I - Username */
-            const char *password)              /* I - Password */
-{
-  struct smbcli_state  *c;             /* New connection */
-  char *myname;                /* Client name */
-  NTSTATUS nt_status;
-
- /*
-  * Get the names and addresses of the client and server...
-  */
-
-  myname = get_myname();  
-       
-  nt_status = smbcli_full_connection(NULL, &c, myname, server, ports, share, 
-                                    NULL, username, workgroup, password, NULL);
-  
-  free(myname);
-  if (!NT_STATUS_IS_OK(nt_status)) {
-         fprintf(stderr, "ERROR:  Connection failed with error %s\n", 
nt_errstr(nt_status));
-         return NULL;
-  }
-
-  /*
-   * Return the new connection...
-   */
-  
-  return (c);
-}
-
-
-/*
- * 'smb_print()' - Queue a job for printing using the SMB protocol.
- */
-
-static int                             /* O - 0 = success, non-0 = failure */
-smb_print(struct smbcli_state *cli,    /* I - SMB connection */
-          char             *title,     /* I - Title/job name */
-          FILE             *fp)                /* I - File to print */
-{
-  int  fnum;           /* File number */
-  int  nbytes,         /* Number of bytes read */
-       tbytes;         /* Total bytes read */


-- 
Samba Shared Repository

Reply via email to