]> git.ipfire.org Git - thirdparty/squid.git/commitdiff
squidclient: Better error checking
authorAmos Jeffries <squid3@treenet.co.nz>
Fri, 16 Nov 2012 07:05:53 +0000 (00:05 -0700)
committerAmos Jeffries <squid3@treenet.co.nz>
Fri, 16 Nov 2012 07:05:53 +0000 (00:05 -0700)
* detect and report fstat() errors which could lead to invalid
  Content-Length being sent.

* remove some useless checks which were causing false positives by Coverity.

 Detected by Coverity Scan. Issues 740334, 740379

tools/squidclient.cc

index c6d937cdb0981a18ecf18e25c9381a7e377eaf6c..1c755870512613b10b59766d62ceace38ba15950 100644 (file)
@@ -265,13 +265,11 @@ main(int argc, char *argv[])
                 break;
 
             case 'A':
-                if (optarg != NULL)
-                    useragent = optarg;
+                useragent = optarg;
                 break;
 
             case 'h':          /* remote host */
-                if (optarg != NULL)
-                    hostname = optarg;
+                hostname = optarg;
                 break;
 
             case 'j':
@@ -279,13 +277,11 @@ main(int argc, char *argv[])
                 break;
 
             case 'V':
-                if (optarg != NULL)
-                    version = optarg;
+                version = optarg;
                 break;
 
             case 'l':          /* local host */
-                if (optarg != NULL)
-                    localhost = optarg;
+                localhost = optarg;
                 break;
 
             case 's':          /* silent */
@@ -418,7 +414,9 @@ main(int argc, char *argv[])
         setmode(put_fd, O_BINARY);
 #endif
 
-        fstat(put_fd, &sb);
+        if (fstat(put_fd, &sb) < 0) {
+            fprintf(stderr, "%s: can't identify length of file (%s)\n", argv[0], xstrerror());
+        }
     }
 
     if (!host) {