mirror of
https://github.com/servo/servo.git
synced 2025-08-03 04:30:10 +01:00
embedding: fix string_list deallocation where I accidentally the whole string_list
This commit is contained in:
parent
2df236376a
commit
021937bca0
1 changed files with 13 additions and 13 deletions
|
@ -22,8 +22,8 @@ pub extern "C" fn cef_string_list_alloc() -> *mut cef_string_list_t {
|
|||
pub extern "C" fn cef_string_list_size(lt: *const cef_string_list_t) -> c_int {
|
||||
unsafe {
|
||||
if fptr_is_null(mem::transmute(lt)) { return 0; }
|
||||
let v: Box<Vec<*mut cef_string_t>> = mem::transmute(lt);
|
||||
v.len() as c_int
|
||||
let v: *const Vec<*mut cef_string_t> = mem::transmute(lt);
|
||||
(*v).len() as c_int
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -31,10 +31,10 @@ pub extern "C" fn cef_string_list_size(lt: *const cef_string_list_t) -> c_int {
|
|||
pub extern "C" fn cef_string_list_append(lt: *mut cef_string_list_t, value: *const cef_string_t) {
|
||||
unsafe {
|
||||
if fptr_is_null(mem::transmute(lt)) { return; }
|
||||
let mut v: Box<Vec<*mut cef_string_t>> = mem::transmute(lt);
|
||||
let v: *const Vec<*mut cef_string_t> = mem::transmute(lt);
|
||||
let cs = cef_string_userfree_utf8_alloc();
|
||||
cef_string_utf8_set(mem::transmute((*value).str), (*value).length, cs, 1);
|
||||
v.push(cs);
|
||||
(*v).push(cs);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -43,8 +43,8 @@ pub extern "C" fn cef_string_list_value(lt: *mut cef_string_list_t, index: c_int
|
|||
unsafe {
|
||||
if index < 0 || fptr_is_null(mem::transmute(lt)) { return 0; }
|
||||
let v: Box<Vec<*mut cef_string_t>> = mem::transmute(lt);
|
||||
if index as uint > v.len() - 1 { return 0; }
|
||||
let cs = v.get(index as uint);
|
||||
if index as uint > (*v).len() - 1 { return 0; }
|
||||
let cs = (*v).get(index as uint);
|
||||
cef_string_utf8_set(mem::transmute((**cs).str), (**cs).length, value, 1)
|
||||
}
|
||||
}
|
||||
|
@ -53,11 +53,11 @@ pub extern "C" fn cef_string_list_value(lt: *mut cef_string_list_t, index: c_int
|
|||
pub extern "C" fn cef_string_list_clear(lt: *mut cef_string_list_t) {
|
||||
unsafe {
|
||||
if fptr_is_null(mem::transmute(lt)) { return; }
|
||||
let mut v: Box<Vec<*mut cef_string_t>> = mem::transmute(lt);
|
||||
if v.len() == 0 { return; }
|
||||
let v: *const Vec<*mut cef_string_t> = mem::transmute(lt);
|
||||
if (*v).len() == 0 { return; }
|
||||
let mut cs;
|
||||
while v.len() != 0 {
|
||||
cs = v.pop();
|
||||
while (*v).len() != 0 {
|
||||
cs = (*v).pop();
|
||||
cef_string_userfree_utf8_free(cs.unwrap());
|
||||
}
|
||||
}
|
||||
|
@ -67,9 +67,9 @@ pub extern "C" fn cef_string_list_clear(lt: *mut cef_string_list_t) {
|
|||
pub extern "C" fn cef_string_list_free(lt: *mut cef_string_list_t) {
|
||||
unsafe {
|
||||
if fptr_is_null(mem::transmute(lt)) { return; }
|
||||
let mut v: Box<Vec<*mut cef_string_t>> = mem::transmute(lt);
|
||||
let v: *const Vec<*mut cef_string_t> = mem::transmute(lt);
|
||||
cef_string_list_clear(lt);
|
||||
drop(v);
|
||||
drop((*v));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -79,7 +79,7 @@ pub extern "C" fn cef_string_list_copy(lt: *mut cef_string_list_t) -> *mut cef_s
|
|||
if fptr_is_null(mem::transmute(lt)) { return 0 as *mut cef_string_list_t; }
|
||||
let v: Box<Vec<*mut cef_string_t>> = mem::transmute(lt);
|
||||
let lt2 = cef_string_list_alloc();
|
||||
for cs in v.iter() {
|
||||
for cs in (*v).iter() {
|
||||
cef_string_list_append(lt2, mem::transmute((*cs)));
|
||||
}
|
||||
lt2
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue