mirror of
https://git.pwmt.org/pwmt/zathura.git
synced 2025-01-19 06:17:52 +01:00
Add a safe_realloc.
Apply patch from Sylvain Laperche.
This commit is contained in:
parent
cc92b38471
commit
8efa5a5f05
1 changed files with 54 additions and 12 deletions
66
zathura.c
66
zathura.c
|
@ -377,6 +377,7 @@ gboolean open_file(char*, char*);
|
||||||
gboolean open_stdin(gchar*);
|
gboolean open_stdin(gchar*);
|
||||||
void open_uri(char*);
|
void open_uri(char*);
|
||||||
void out_of_memory(void) NORETURN;
|
void out_of_memory(void) NORETURN;
|
||||||
|
void* safe_realloc(void** ptr, size_t nmemb, size_t size);
|
||||||
void update_status(void);
|
void update_status(void);
|
||||||
void read_bookmarks_file(void);
|
void read_bookmarks_file(void);
|
||||||
void write_bookmarks_file(void);
|
void write_bookmarks_file(void);
|
||||||
|
@ -825,8 +826,10 @@ add_marker(int id)
|
||||||
|
|
||||||
/* add new marker */
|
/* add new marker */
|
||||||
int marker_index = Zathura.Marker.number_of_markers++;
|
int marker_index = Zathura.Marker.number_of_markers++;
|
||||||
Zathura.Marker.markers = realloc(Zathura.Marker.markers, sizeof(Marker) *
|
Zathura.Marker.markers = safe_realloc((void**)&Zathura.Marker.markers,
|
||||||
(Zathura.Marker.number_of_markers));
|
Zathura.Marker.number_of_markers, sizeof(Marker));
|
||||||
|
if(!Zathura.Marker.markers)
|
||||||
|
out_of_memory();
|
||||||
|
|
||||||
Zathura.Marker.markers[marker_index].id = id;
|
Zathura.Marker.markers[marker_index].id = id;
|
||||||
Zathura.Marker.markers[marker_index].page = page_number;
|
Zathura.Marker.markers[marker_index].page = page_number;
|
||||||
|
@ -1429,8 +1432,10 @@ open_file(char* path, char* password)
|
||||||
{
|
{
|
||||||
if(!is_reserved_bm_name(keys[i]))
|
if(!is_reserved_bm_name(keys[i]))
|
||||||
{
|
{
|
||||||
Zathura.Bookmarks.bookmarks = realloc(Zathura.Bookmarks.bookmarks,
|
Zathura.Bookmarks.bookmarks = safe_realloc((void**)&Zathura.Bookmarks.bookmarks,
|
||||||
(Zathura.Bookmarks.number_of_bookmarks + 1) * sizeof(Bookmark));
|
Zathura.Bookmarks.number_of_bookmarks + 1, sizeof(Bookmark));
|
||||||
|
if(!Zathura.Bookmarks.bookmarks)
|
||||||
|
out_of_memory();
|
||||||
|
|
||||||
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].id = g_strdup(keys[i]);
|
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].id = g_strdup(keys[i]);
|
||||||
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].page =
|
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].page =
|
||||||
|
@ -1535,6 +1540,31 @@ void out_of_memory(void)
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void*
|
||||||
|
safe_realloc(void** ptr, size_t nmemb, size_t size)
|
||||||
|
{
|
||||||
|
static const size_t limit = ~((size_t)0u);
|
||||||
|
void* tmp = NULL;
|
||||||
|
|
||||||
|
/* Check for overflow. */
|
||||||
|
if(nmemb > limit / size)
|
||||||
|
goto failure;
|
||||||
|
|
||||||
|
tmp = realloc(*ptr, nmemb * size);
|
||||||
|
/* Check for out of memory. */
|
||||||
|
if(!tmp)
|
||||||
|
goto failure;
|
||||||
|
|
||||||
|
*ptr = tmp;
|
||||||
|
return *ptr;
|
||||||
|
|
||||||
|
/* Error handling. */
|
||||||
|
failure:
|
||||||
|
free(*ptr);
|
||||||
|
*ptr = NULL;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
update_status(void)
|
update_status(void)
|
||||||
{
|
{
|
||||||
|
@ -2901,7 +2931,9 @@ isc_completion(Argument* argument)
|
||||||
{
|
{
|
||||||
if(group->value && !group_elements)
|
if(group->value && !group_elements)
|
||||||
{
|
{
|
||||||
rows = realloc(rows, (n_items + 1) * sizeof(CompletionRow));
|
rows = safe_realloc((void**)&rows, n_items + 1, sizeof(CompletionRow));
|
||||||
|
if(!rows)
|
||||||
|
out_of_memory();
|
||||||
rows[n_items].command = g_strdup(group->value);
|
rows[n_items].command = g_strdup(group->value);
|
||||||
rows[n_items].description = NULL;
|
rows[n_items].description = NULL;
|
||||||
rows[n_items].command_id = -1;
|
rows[n_items].command_id = -1;
|
||||||
|
@ -2909,7 +2941,9 @@ isc_completion(Argument* argument)
|
||||||
rows[n_items++].row = GTK_WIDGET(create_completion_row(results, group->value, NULL, TRUE));
|
rows[n_items++].row = GTK_WIDGET(create_completion_row(results, group->value, NULL, TRUE));
|
||||||
}
|
}
|
||||||
|
|
||||||
rows = realloc(rows, (n_items + 1) * sizeof(CompletionRow));
|
rows = safe_realloc((void**)&rows, n_items + 1, sizeof(CompletionRow));
|
||||||
|
if(!rows)
|
||||||
|
out_of_memory();
|
||||||
rows[n_items].command = g_strdup(element->value);
|
rows[n_items].command = g_strdup(element->value);
|
||||||
rows[n_items].description = element->description ? g_strdup(element->description) : NULL;
|
rows[n_items].description = element->description ? g_strdup(element->description) : NULL;
|
||||||
rows[n_items].command_id = previous_id;
|
rows[n_items].command_id = previous_id;
|
||||||
|
@ -2954,7 +2988,9 @@ isc_completion(Argument* argument)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
rows = realloc(rows, n_items * sizeof(CompletionRow));
|
rows = safe_realloc((void**)&rows, n_items, sizeof(CompletionRow));
|
||||||
|
if(!rows)
|
||||||
|
out_of_memory();
|
||||||
}
|
}
|
||||||
|
|
||||||
gtk_box_pack_start(Zathura.UI.box, GTK_WIDGET(results), FALSE, FALSE, 0);
|
gtk_box_pack_start(Zathura.UI.box, GTK_WIDGET(results), FALSE, FALSE, 0);
|
||||||
|
@ -3127,8 +3163,10 @@ cmd_bookmark(int argc, char** argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* add new bookmark */
|
/* add new bookmark */
|
||||||
Zathura.Bookmarks.bookmarks = realloc(Zathura.Bookmarks.bookmarks,
|
Zathura.Bookmarks.bookmarks = safe_realloc((void**)&Zathura.Bookmarks.bookmarks,
|
||||||
(Zathura.Bookmarks.number_of_bookmarks + 1) * sizeof(Bookmark));
|
Zathura.Bookmarks.number_of_bookmarks + 1, sizeof(Bookmark));
|
||||||
|
if(!Zathura.Bookmarks.bookmarks)
|
||||||
|
out_of_memory();
|
||||||
|
|
||||||
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].id = g_strdup(id->str);
|
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].id = g_strdup(id->str);
|
||||||
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].page = Zathura.PDF.page_number;
|
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].page = Zathura.PDF.page_number;
|
||||||
|
@ -3234,8 +3272,10 @@ cmd_delete_bookmark(int argc, char** argv)
|
||||||
/* update bookmarks */
|
/* update bookmarks */
|
||||||
Zathura.Bookmarks.bookmarks[i].id = Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks - 1].id;
|
Zathura.Bookmarks.bookmarks[i].id = Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks - 1].id;
|
||||||
Zathura.Bookmarks.bookmarks[i].page = Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks - 1].page;
|
Zathura.Bookmarks.bookmarks[i].page = Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks - 1].page;
|
||||||
Zathura.Bookmarks.bookmarks = realloc(Zathura.Bookmarks.bookmarks,
|
Zathura.Bookmarks.bookmarks = safe_realloc((void**)&Zathura.Bookmarks.bookmarks,
|
||||||
Zathura.Bookmarks.number_of_bookmarks * sizeof(Bookmark));
|
Zathura.Bookmarks.number_of_bookmarks, sizeof(Bookmark));
|
||||||
|
if(!Zathura.Bookmarks.bookmarks)
|
||||||
|
out_of_memory();
|
||||||
|
|
||||||
Zathura.Bookmarks.number_of_bookmarks--;
|
Zathura.Bookmarks.number_of_bookmarks--;
|
||||||
g_string_free(id, TRUE);
|
g_string_free(id, TRUE);
|
||||||
|
@ -4025,7 +4065,9 @@ cc_print(char* input)
|
||||||
if(!current_line)
|
if(!current_line)
|
||||||
out_of_memory();
|
out_of_memory();
|
||||||
|
|
||||||
current_line = realloc(current_line, (count + 1) * sizeof(char));
|
current_line = safe_realloc((void**)¤t_line, count + 1, sizeof(char));
|
||||||
|
if(!current_line)
|
||||||
|
out_of_memory();
|
||||||
|
|
||||||
if(current_char != '\n')
|
if(current_char != '\n')
|
||||||
current_line[count++] = current_char;
|
current_line[count++] = current_char;
|
||||||
|
|
Loading…
Reference in a new issue