mirror of
https://github.com/ZoiteChat/zoitechat.git
synced 2026-06-09 00:10:18 +00:00
Merge pull request #239 from ZoiteChat/size_t_int_fixes
Size t int fixes
This commit is contained in:
@@ -4397,7 +4397,7 @@ void
|
|||||||
check_special_chars (char *cmd, int do_ascii) /* check for %X */
|
check_special_chars (char *cmd, int do_ascii) /* check for %X */
|
||||||
{
|
{
|
||||||
int occur = 0;
|
int occur = 0;
|
||||||
int len = strlen (cmd);
|
size_t len = strlen (cmd);
|
||||||
char *buf, *utf;
|
char *buf, *utf;
|
||||||
char tbuf[4];
|
char tbuf[4];
|
||||||
int i = 0, j = 0;
|
int i = 0, j = 0;
|
||||||
|
|||||||
@@ -1017,7 +1017,7 @@ process_named_msg (session *sess, char *type, char *word[], char *word_eol[],
|
|||||||
char *account;
|
char *account;
|
||||||
char ip[128], nick[NICKLEN];
|
char ip[128], nick[NICKLEN];
|
||||||
char *text, *ex;
|
char *text, *ex;
|
||||||
int len = strlen (type);
|
size_t len = strlen (type);
|
||||||
|
|
||||||
/* fill in the "ip" and "nick" buffers */
|
/* fill in the "ip" and "nick" buffers */
|
||||||
ex = strchr (word[1], '!');
|
ex = strchr (word[1], '!');
|
||||||
|
|||||||
@@ -22,6 +22,7 @@
|
|||||||
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
|
#include <limits.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
@@ -74,6 +75,18 @@ typedef struct
|
|||||||
static bool string_builder_init (StringBuilder *builder);
|
static bool string_builder_init (StringBuilder *builder);
|
||||||
static void string_builder_free (StringBuilder *builder);
|
static void string_builder_free (StringBuilder *builder);
|
||||||
static bool string_builder_append (StringBuilder *builder, const char *text);
|
static bool string_builder_append (StringBuilder *builder, const char *text);
|
||||||
|
static int size_to_int (size_t value);
|
||||||
|
|
||||||
|
static int
|
||||||
|
size_to_int (size_t value)
|
||||||
|
{
|
||||||
|
if (value > (size_t) INT_MAX)
|
||||||
|
{
|
||||||
|
return INT_MAX;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (int) value;
|
||||||
|
}
|
||||||
|
|
||||||
char *
|
char *
|
||||||
sysinfo_get_cpu (void)
|
sysinfo_get_cpu (void)
|
||||||
@@ -511,6 +524,7 @@ static char *read_hdd_info (IWbemClassObject *object)
|
|||||||
static char *bstr_to_utf8 (BSTR bstr)
|
static char *bstr_to_utf8 (BSTR bstr)
|
||||||
{
|
{
|
||||||
int utf8_len;
|
int utf8_len;
|
||||||
|
int wide_len;
|
||||||
char *utf8;
|
char *utf8;
|
||||||
|
|
||||||
if (bstr == NULL)
|
if (bstr == NULL)
|
||||||
@@ -518,7 +532,8 @@ static char *bstr_to_utf8 (BSTR bstr)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
utf8_len = WideCharToMultiByte (CP_UTF8, 0, bstr, SysStringLen (bstr), NULL, 0, NULL, NULL);
|
wide_len = size_to_int ((size_t) SysStringLen (bstr));
|
||||||
|
utf8_len = WideCharToMultiByte (CP_UTF8, 0, bstr, wide_len, NULL, 0, NULL, NULL);
|
||||||
if (utf8_len <= 0)
|
if (utf8_len <= 0)
|
||||||
{
|
{
|
||||||
return NULL;
|
return NULL;
|
||||||
@@ -530,7 +545,7 @@ static char *bstr_to_utf8 (BSTR bstr)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (WideCharToMultiByte (CP_UTF8, 0, bstr, SysStringLen (bstr), utf8, utf8_len, NULL, NULL) <= 0)
|
if (WideCharToMultiByte (CP_UTF8, 0, bstr, wide_len, utf8, utf8_len, NULL, NULL) <= 0)
|
||||||
{
|
{
|
||||||
free (utf8);
|
free (utf8);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|||||||
@@ -321,7 +321,7 @@ url_check_line (char *buf)
|
|||||||
for (i = 0; i < ARRAY_SIZE (commands); i++)
|
for (i = 0; i < ARRAY_SIZE (commands); i++)
|
||||||
{
|
{
|
||||||
char *cmd = commands[i];
|
char *cmd = commands[i];
|
||||||
int len = strlen (cmd);
|
size_t len = strlen (cmd);
|
||||||
|
|
||||||
if (strncmp (cmd, po, len) == 0)
|
if (strncmp (cmd, po, len) == 0)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -98,7 +98,7 @@ path_part (char *file, char *path, int pathlen)
|
|||||||
char * /* like strstr(), but nocase */
|
char * /* like strstr(), but nocase */
|
||||||
nocasestrstr (const char *s, const char *wanted)
|
nocasestrstr (const char *s, const char *wanted)
|
||||||
{
|
{
|
||||||
register const int len = strlen (wanted);
|
register const size_t len = strlen (wanted);
|
||||||
|
|
||||||
if (len == 0)
|
if (len == 0)
|
||||||
return (char *)s;
|
return (char *)s;
|
||||||
|
|||||||
@@ -452,7 +452,7 @@ void
|
|||||||
fe_add_chan_list (server *serv, char *chan, char *users, char *topic)
|
fe_add_chan_list (server *serv, char *chan, char *users, char *topic)
|
||||||
{
|
{
|
||||||
chanlistrow *next_row;
|
chanlistrow *next_row;
|
||||||
int len = strlen (chan) + 1;
|
size_t len = strlen (chan) + 1;
|
||||||
|
|
||||||
/* we allocate the struct and channel string in one go */
|
/* we allocate the struct and channel string in one go */
|
||||||
next_row = g_malloc (sizeof (chanlistrow) + len);
|
next_row = g_malloc (sizeof (chanlistrow) + len);
|
||||||
|
|||||||
@@ -976,7 +976,7 @@ gtkutil_copy_to_clipboard (GtkWidget *widget, GdkAtom selection,
|
|||||||
win = gtk_widget_get_toplevel (GTK_WIDGET (widget));
|
win = gtk_widget_get_toplevel (GTK_WIDGET (widget));
|
||||||
if (gtk_widget_is_toplevel (win))
|
if (gtk_widget_is_toplevel (win))
|
||||||
{
|
{
|
||||||
int len = strlen (str);
|
gint len = (gint) strlen (str);
|
||||||
|
|
||||||
if (selection)
|
if (selection)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -2309,7 +2309,7 @@ menu_reorder (GtkMenu *menu, GtkWidget *item, int pos)
|
|||||||
if (pos < 0) /* position offset from end/bottom */
|
if (pos < 0) /* position offset from end/bottom */
|
||||||
{
|
{
|
||||||
GList *children = gtk_container_get_children (GTK_CONTAINER (menu));
|
GList *children = gtk_container_get_children (GTK_CONTAINER (menu));
|
||||||
int length = g_list_length (children);
|
gint length = (gint) g_list_length (children);
|
||||||
|
|
||||||
g_list_free (children);
|
g_list_free (children);
|
||||||
gtk_menu_reorder_child (menu, item, (length + pos) - 1);
|
gtk_menu_reorder_child (menu, item, (length + pos) - 1);
|
||||||
@@ -2381,7 +2381,7 @@ menu_add_sub (GtkWidget *menu, menu_entry *me)
|
|||||||
if (pos < 0) /* position offset from end/bottom */
|
if (pos < 0) /* position offset from end/bottom */
|
||||||
{
|
{
|
||||||
GList *children = gtk_container_get_children (GTK_CONTAINER (menu));
|
GList *children = gtk_container_get_children (GTK_CONTAINER (menu));
|
||||||
int length = g_list_length (children);
|
gint length = (gint) g_list_length (children);
|
||||||
|
|
||||||
g_list_free (children);
|
g_list_free (children);
|
||||||
pos = length + pos;
|
pos = length + pos;
|
||||||
|
|||||||
@@ -1364,7 +1364,7 @@ setup_entry_cb (GtkEntry *entry, setting *set)
|
|||||||
int size;
|
int size;
|
||||||
int pos;
|
int pos;
|
||||||
unsigned char *p = (unsigned char*)gtk_entry_get_text (entry);
|
unsigned char *p = (unsigned char*)gtk_entry_get_text (entry);
|
||||||
int len = strlen (p);
|
size_t len = strlen ((const char *) p);
|
||||||
|
|
||||||
/* need to truncate? */
|
/* need to truncate? */
|
||||||
if (len >= set->extra)
|
if (len >= set->extra)
|
||||||
@@ -2180,7 +2180,7 @@ unslash (char *dir)
|
|||||||
{
|
{
|
||||||
if (dir[0])
|
if (dir[0])
|
||||||
{
|
{
|
||||||
int len = strlen (dir) - 1;
|
size_t len = strlen (dir) - 1;
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
if (dir[len] == '/' || dir[len] == '\\')
|
if (dir[len] == '/' || dir[len] == '\\')
|
||||||
#else
|
#else
|
||||||
|
|||||||
@@ -313,7 +313,8 @@ fe_print_text (struct session *sess, char *text, time_t stamp,
|
|||||||
gboolean no_activity)
|
gboolean no_activity)
|
||||||
{
|
{
|
||||||
int dotime = FALSE;
|
int dotime = FALSE;
|
||||||
int comma, k, i = 0, j = 0, len = strlen (text);
|
int comma, k, i = 0, j = 0;
|
||||||
|
size_t len = strlen (text);
|
||||||
|
|
||||||
unsigned char *newtext = g_malloc (len + 1024);
|
unsigned char *newtext = g_malloc (len + 1024);
|
||||||
|
|
||||||
|
|||||||
@@ -26,12 +26,19 @@
|
|||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
|
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
|
#include <climits>
|
||||||
|
|
||||||
#include "typedef.h" // for ssize_t
|
#include "typedef.h" // for ssize_t
|
||||||
#include <enchant-provider.h>
|
#include <enchant-provider.h>
|
||||||
|
|
||||||
ENCHANT_PLUGIN_DECLARE ("win8")
|
ENCHANT_PLUGIN_DECLARE ("win8")
|
||||||
|
|
||||||
|
static int
|
||||||
|
size_to_int (size_t value)
|
||||||
|
{
|
||||||
|
return value > static_cast<size_t>(INT_MAX) ? INT_MAX : static_cast<int>(value);
|
||||||
|
}
|
||||||
|
|
||||||
static char *
|
static char *
|
||||||
utf16_to_utf8 (const wchar_t * const str, bool from_bcp47)
|
utf16_to_utf8 (const wchar_t * const str, bool from_bcp47)
|
||||||
{
|
{
|
||||||
@@ -136,7 +143,7 @@ static void
|
|||||||
win8_dict_add_to_personal (EnchantDict *dict, const char *const word, size_t len)
|
win8_dict_add_to_personal (EnchantDict *dict, const char *const word, size_t len)
|
||||||
{
|
{
|
||||||
auto checker = static_cast<ISpellChecker*>(dict->user_data);
|
auto checker = static_cast<ISpellChecker*>(dict->user_data);
|
||||||
wchar_t *wword = utf8_to_utf16 (word, static_cast<int>(len), false);
|
wchar_t *wword = utf8_to_utf16 (word, size_to_int (len), false);
|
||||||
|
|
||||||
checker->Add (wword);
|
checker->Add (wword);
|
||||||
std::free (wword);
|
std::free (wword);
|
||||||
@@ -146,7 +153,7 @@ static void
|
|||||||
win8_dict_add_to_session (EnchantDict *dict, const char *const word, size_t len)
|
win8_dict_add_to_session (EnchantDict *dict, const char *const word, size_t len)
|
||||||
{
|
{
|
||||||
auto checker = static_cast<ISpellChecker*>(dict->user_data);
|
auto checker = static_cast<ISpellChecker*>(dict->user_data);
|
||||||
wchar_t *wword = utf8_to_utf16 (word, static_cast<int>(len), false);
|
wchar_t *wword = utf8_to_utf16 (word, size_to_int (len), false);
|
||||||
|
|
||||||
checker->Ignore (wword);
|
checker->Ignore (wword);
|
||||||
std::free (wword);
|
std::free (wword);
|
||||||
@@ -156,7 +163,7 @@ static int
|
|||||||
win8_dict_check (EnchantDict *dict, const char *const word, size_t len)
|
win8_dict_check (EnchantDict *dict, const char *const word, size_t len)
|
||||||
{
|
{
|
||||||
auto checker = static_cast<ISpellChecker*>(dict->user_data);
|
auto checker = static_cast<ISpellChecker*>(dict->user_data);
|
||||||
wchar_t *wword = utf8_to_utf16 (word, static_cast<int>(len), false);
|
wchar_t *wword = utf8_to_utf16 (word, size_to_int (len), false);
|
||||||
IEnumSpellingError *errors;
|
IEnumSpellingError *errors;
|
||||||
ISpellingError *error = nullptr;
|
ISpellingError *error = nullptr;
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
@@ -184,7 +191,7 @@ static char **
|
|||||||
win8_dict_suggest (EnchantDict *dict, const char *const word, size_t len, size_t *out_n_suggs)
|
win8_dict_suggest (EnchantDict *dict, const char *const word, size_t len, size_t *out_n_suggs)
|
||||||
{
|
{
|
||||||
auto checker = static_cast<ISpellChecker*>(dict->user_data);
|
auto checker = static_cast<ISpellChecker*>(dict->user_data);
|
||||||
wchar_t *wword = utf8_to_utf16 (word, static_cast<int>(len), false);
|
wchar_t *wword = utf8_to_utf16 (word, size_to_int (len), false);
|
||||||
IEnumString *suggestions;
|
IEnumString *suggestions;
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user