/*
* Copyright (C) 2011-2024 Free Software Foundation, Inc.
*
* 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 . */
#include
#include
#include "signature.h"
#ifndef strtoll
SIGNATURE_CHECK (strtoll, long long, (const char *, char **, int));
#endif
#include
#include "macros.h"
int
main (void)
{
/* Subject sequence empty or invalid. */
{
const char input[] = "";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 0);
ASSERT (ptr == input);
ASSERT (errno == 0 || errno == EINVAL);
}
{
const char input[] = " ";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 0);
ASSERT (ptr == input);
ASSERT (errno == 0 || errno == EINVAL);
}
{
const char input[] = " +";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 0);
ASSERT (ptr == input);
ASSERT (errno == 0 || errno == EINVAL);
}
{
const char input[] = " -";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 0);
ASSERT (ptr == input);
ASSERT (errno == 0 || errno == EINVAL);
}
/* Simple integer values. */
{
const char input[] = "0";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 0);
ASSERT (ptr == input + 1);
ASSERT (errno == 0);
}
{
const char input[] = "+0";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 0);
ASSERT (ptr == input + 2);
ASSERT (errno == 0);
}
{
const char input[] = "-0";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 0);
ASSERT (ptr == input + 2);
ASSERT (errno == 0);
}
{
const char input[] = "23";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 23);
ASSERT (ptr == input + 2);
ASSERT (errno == 0);
}
{
const char input[] = " 23";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 23);
ASSERT (ptr == input + 3);
ASSERT (errno == 0);
}
{
const char input[] = "+23";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 23);
ASSERT (ptr == input + 3);
ASSERT (errno == 0);
}
{
const char input[] = "-23";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == -23);
ASSERT (ptr == input + 3);
ASSERT (errno == 0);
}
/* Large integer values. */
{
const char input[] = "2147483647";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 2147483647);
ASSERT (ptr == input + 10);
ASSERT (errno == 0);
}
{
const char input[] = "-2147483648";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == -2147483647 - 1);
ASSERT (ptr == input + 11);
ASSERT (errno == 0);
}
if (sizeof (long long) > sizeof (int))
{
const char input[] = "4294967295";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 65535LL * 65537LL);
ASSERT (ptr == input + 10);
ASSERT (errno == 0);
}
/* Hexadecimal integer syntax. */
{
const char input[] = "0x2A";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 0LL);
ASSERT (ptr == input + 1);
ASSERT (errno == 0);
}
{
const char input[] = "0x2A";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 16);
ASSERT (result == 42LL);
ASSERT (ptr == input + 4);
ASSERT (errno == 0);
}
{
const char input[] = "0x2A";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 0);
ASSERT (result == 42LL);
ASSERT (ptr == input + 4);
ASSERT (errno == 0);
}
{
const char input[] = "0x";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 0LL);
ASSERT (ptr == input + 1);
ASSERT (errno == 0);
}
{
const char input[] = "0x";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 16);
ASSERT (result == 0LL);
ASSERT (ptr == input + 1);
ASSERT (errno == 0);
}
{
const char input[] = "0x";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 0);
ASSERT (result == 0LL);
ASSERT (ptr == input + 1);
ASSERT (errno == 0);
}
/* Binary integer syntax. */
{
const char input[] = "0b111010";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 0LL);
ASSERT (ptr == input + 1);
ASSERT (errno == 0);
}
{
const char input[] = "0b111010";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 2);
ASSERT (result == 58LL);
ASSERT (ptr == input + 8);
ASSERT (errno == 0);
}
{
const char input[] = "0b111010";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 0);
ASSERT (result == 58LL);
ASSERT (ptr == input + 8);
ASSERT (errno == 0);
}
{
const char input[] = "0b";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 10);
ASSERT (result == 0LL);
ASSERT (ptr == input + 1);
ASSERT (errno == 0);
}
{
const char input[] = "0b";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 2);
ASSERT (result == 0LL);
ASSERT (ptr == input + 1);
ASSERT (errno == 0);
}
{
const char input[] = "0b";
char *ptr;
long long result;
errno = 0;
result = strtoll (input, &ptr, 0);
ASSERT (result == 0LL);
ASSERT (ptr == input + 1);
ASSERT (errno == 0);
}
return 0;
}