mirror of
https://github.com/chatmail/core.git
synced 2026-05-08 17:36:29 +03:00
(dig,hpk) pull out job collection from sql query/lock logic
This commit is contained in:
@@ -1962,7 +1962,7 @@ pub unsafe fn dc_forward_msgs(
|
|||||||
curr_timestamp = dc_create_smeared_timestamps(context, msg_cnt);
|
curr_timestamp = dc_create_smeared_timestamps(context, msg_cnt);
|
||||||
idsstr = dc_arr_to_string(msg_ids, msg_cnt);
|
idsstr = dc_arr_to_string(msg_ids, msg_cnt);
|
||||||
|
|
||||||
context
|
let ids = context
|
||||||
.sql
|
.sql
|
||||||
.query_map(
|
.query_map(
|
||||||
format!(
|
format!(
|
||||||
@@ -1972,8 +1972,12 @@ pub unsafe fn dc_forward_msgs(
|
|||||||
params![],
|
params![],
|
||||||
|row| row.get::<_, i32>(0),
|
|row| row.get::<_, i32>(0),
|
||||||
|ids| {
|
|ids| {
|
||||||
for id in ids {
|
ids.collect::<Result<Vec<_>, _>>().map_err(Into::into)
|
||||||
let src_msg_id = id?;
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
for id in ids.unwrap() {
|
||||||
|
let src_msg_id = id;
|
||||||
if !dc_msg_load_from_db(msg, context, src_msg_id as u32) {
|
if !dc_msg_load_from_db(msg, context, src_msg_id as u32) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -2025,10 +2029,6 @@ pub unsafe fn dc_forward_msgs(
|
|||||||
0 as *mut libc::c_uint,
|
0 as *mut libc::c_uint,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
Ok(())
|
|
||||||
},
|
|
||||||
)
|
|
||||||
.unwrap(); // TODO: better error handling
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if !created_db_entries.is_null() {
|
if !created_db_entries.is_null() {
|
||||||
|
|||||||
@@ -80,12 +80,14 @@ unsafe fn dc_job_perform(context: &Context, thread: libc::c_int, probe_network:
|
|||||||
params_probe
|
params_probe
|
||||||
};
|
};
|
||||||
|
|
||||||
let jobs: Vec<dc_job_t> = context
|
info!(context, 0, "dc_job_perform before query");
|
||||||
|
let jobs: Result<Vec<dc_job_t>,_> = context
|
||||||
.sql
|
.sql
|
||||||
.query_map(
|
.query_map(
|
||||||
query,
|
query,
|
||||||
params,
|
params,
|
||||||
|row| {
|
|row| {
|
||||||
|
info!(context, 0, "START jobs query_maps");
|
||||||
let job = dc_job_t {
|
let job = dc_job_t {
|
||||||
job_id: row.get(0)?,
|
job_id: row.get(0)?,
|
||||||
action: row.get(1)?,
|
action: row.get(1)?,
|
||||||
@@ -100,16 +102,22 @@ unsafe fn dc_job_perform(context: &Context, thread: libc::c_int, probe_network:
|
|||||||
|
|
||||||
let packed: String = row.get(3)?;
|
let packed: String = row.get(3)?;
|
||||||
dc_param_set_packed(job.param, to_cstring(packed).as_ptr());
|
dc_param_set_packed(job.param, to_cstring(packed).as_ptr());
|
||||||
|
info!(context, 0, "DONE jobs query_maps row");
|
||||||
Ok(job)
|
Ok(job)
|
||||||
},
|
},
|
||||||
|jobs| {
|
|jobs| {
|
||||||
jobs.collect::<Result<Vec<dc_job_t>, _>>()
|
info!(context, 0, "collecting jobs");
|
||||||
.map_err(Into::into)
|
let res = jobs.collect::<Result<Vec<dc_job_t>, _>>()
|
||||||
|
.map_err(Into::into);
|
||||||
|
info!(context, 0, "collecting jobs done");
|
||||||
|
res
|
||||||
},
|
},
|
||||||
)
|
);
|
||||||
.unwrap_or_default();
|
match jobs {
|
||||||
|
Ok(ref res) => {info!(context, 0, "query done, {:?}", res.len()); },
|
||||||
for mut job in jobs {
|
Err(ref err) => {info!(context, 0, "query failed: {:?}", err); }
|
||||||
|
}
|
||||||
|
for mut job in jobs.unwrap_or_default() {
|
||||||
info!(
|
info!(
|
||||||
context,
|
context,
|
||||||
0,
|
0,
|
||||||
|
|||||||
30
src/imap.rs
30
src/imap.rs
@@ -471,24 +471,9 @@ impl Imap {
|
|||||||
fn unsetup_handle(&self, context: &Context) {
|
fn unsetup_handle(&self, context: &Context) {
|
||||||
info!(context, 0, "IMAP unsetup_handle starts");
|
info!(context, 0, "IMAP unsetup_handle starts");
|
||||||
|
|
||||||
// XXX the next line currently can block even if all threads
|
|
||||||
// terminated already
|
|
||||||
let session = self.session.lock().unwrap().take();
|
|
||||||
info!(
|
info!(
|
||||||
context,
|
context,
|
||||||
0, "IMAP unsetup_handle step1 (acquired session.lock)"
|
0, "IMAP unsetup_handle step 1 (closing down stream)."
|
||||||
);
|
|
||||||
if session.is_some() {
|
|
||||||
match session.unwrap().close() {
|
|
||||||
Ok(_) => {}
|
|
||||||
Err(err) => {
|
|
||||||
eprintln!("failed to close connection: {:?}", err);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
info!(
|
|
||||||
context,
|
|
||||||
0, "IMAP unsetup_handle step 2 (closing down stream)."
|
|
||||||
);
|
);
|
||||||
let stream = self.stream.write().unwrap().take();
|
let stream = self.stream.write().unwrap().take();
|
||||||
if stream.is_some() {
|
if stream.is_some() {
|
||||||
@@ -499,6 +484,19 @@ impl Imap {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
info!(
|
||||||
|
context,
|
||||||
|
0, "IMAP unsetup_handle step 2 (acquired session.lock)"
|
||||||
|
);
|
||||||
|
let session = self.session.lock().unwrap().take();
|
||||||
|
if session.is_some() {
|
||||||
|
match session.unwrap().close() {
|
||||||
|
Ok(_) => {}
|
||||||
|
Err(err) => {
|
||||||
|
eprintln!("failed to close connection: {:?}", err);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
info!(context, 0, "IMAP unsetup_handle step 3 (clearing config).");
|
info!(context, 0, "IMAP unsetup_handle step 3 (clearing config).");
|
||||||
self.config.write().unwrap().selected_folder = None;
|
self.config.write().unwrap().selected_folder = None;
|
||||||
|
|||||||
Reference in New Issue
Block a user