mirror of
				https://github.com/PowerShell/openssh-portable.git
				synced 2025-10-25 09:33:58 +02:00 
			
		
		
		
	* codeql fixes * fix type mismatches * fix pointers in w32_time methods * fixes for codeQL warnings * modify checks for codeql warnings * add comments for codeql suppressions * additional codeql fixes and suppressions * add codeql fixes * add comments for codeql * add comments for codeql * switch from debug to error log messages * fix another merge conflict fix line endings in gss-sspi.c * add null check in channels.c * address PR feedback * address additional review feedback * add CodeQL comments to common code * fix unittest-win32compat * fix unit test * address review feedback * remove suppression
		
			
				
	
	
		
			73 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*	$OpenBSD: strtonum.c,v 1.6 2004/08/03 19:38:01 millert Exp $	*/
 | |
| 
 | |
| /*
 | |
|  * Copyright (c) 2004 Ted Unangst and Todd Miller
 | |
|  * All rights reserved.
 | |
|  *
 | |
|  * Permission to use, copy, modify, and distribute this software for any
 | |
|  * purpose with or without fee is hereby granted, provided that the above
 | |
|  * copyright notice and this permission notice appear in all copies.
 | |
|  *
 | |
|  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 | |
|  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 | |
|  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
 | |
|  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 | |
|  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
 | |
|  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
 | |
|  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 | |
|  */
 | |
| 
 | |
| /* OPENBSD ORIGINAL: lib/libc/stdlib/strtonum.c */
 | |
| 
 | |
| #include "includes.h"
 | |
| 
 | |
| #ifndef HAVE_STRTONUM
 | |
| #include <stdlib.h>
 | |
| #include <limits.h>
 | |
| #include <errno.h>
 | |
| 
 | |
| #define INVALID		1
 | |
| #define TOOSMALL	2
 | |
| #define TOOLARGE	3
 | |
| 
 | |
| long long
 | |
| strtonum(const char *numstr, long long minval, long long maxval,
 | |
|     const char **errstrp)
 | |
| {
 | |
| 	long long ll = 0;
 | |
| 	char *ep;
 | |
| 	int error = 0;
 | |
| 	struct errval {
 | |
| 		const char *errstr;
 | |
| 		int err;
 | |
| 	} ev[4] = {
 | |
| 		{ NULL,		0 },
 | |
| 		{ "invalid",	EINVAL },
 | |
| 		{ "too small",	ERANGE },
 | |
| 		{ "too large",	ERANGE },
 | |
| 	};
 | |
| 
 | |
| 	ev[0].err = errno;
 | |
| 	errno = 0;
 | |
| 	if (minval > maxval)
 | |
| 		error = INVALID;
 | |
| 	else {
 | |
| 		ll = strtoll(numstr, &ep, 10); // CodeQL [SM02313]: strtoll will initialize ep
 | |
| 		if (numstr == ep || *ep != '\0')
 | |
| 			error = INVALID;
 | |
| 		else if ((ll == LLONG_MIN && errno == ERANGE) || ll < minval)
 | |
| 			error = TOOSMALL;
 | |
| 		else if ((ll == LLONG_MAX && errno == ERANGE) || ll > maxval)
 | |
| 			error = TOOLARGE;
 | |
| 	}
 | |
| 	if (errstrp != NULL)
 | |
| 		*errstrp = ev[error].errstr;
 | |
| 	errno = ev[error].err;
 | |
| 	if (error)
 | |
| 		ll = 0;
 | |
| 
 | |
| 	return (ll);
 | |
| }
 | |
| 
 | |
| #endif /* HAVE_STRTONUM */
 |