finer concurrency

This commit is contained in:
Aleksey Kladov 2018-08-01 22:07:09 +03:00
parent 1954df6336
commit 7264c3294b
3 changed files with 14 additions and 11 deletions

View file

@ -12,6 +12,7 @@ unicode-xid = "0.1.0"
text_unit = "0.1.2" text_unit = "0.1.2"
itertools = "0.7.5" itertools = "0.7.5"
drop_bomb = "0.1.4" drop_bomb = "0.1.4"
parking_lot = "0.6.0"
[dev-dependencies] [dev-dependencies]
testutils = { path = "./tests/testutils" } testutils = { path = "./tests/testutils" }

View file

@ -24,6 +24,7 @@ extern crate itertools;
extern crate text_unit; extern crate text_unit;
extern crate unicode_xid; extern crate unicode_xid;
extern crate drop_bomb; extern crate drop_bomb;
extern crate parking_lot;
pub mod algo; pub mod algo;
pub mod ast; pub mod ast;

View file

@ -1,4 +1,5 @@
use std::{ptr, sync::RwLock}; use std::ptr;
use parking_lot::RwLock;
use {yellow::GreenNode, TextUnit}; use {yellow::GreenNode, TextUnit};
#[derive(Debug)] #[derive(Debug)]
@ -66,12 +67,10 @@ impl RedNode {
if idx >= self.n_children() { if idx >= self.n_children() {
return None; return None;
} }
match &self.children.read().unwrap()[idx] { match &self.children.read()[idx] {
Some(child) => return Some(child.into()), Some(child) => return Some(child.into()),
None => (), None => (),
} }
let mut children = self.children.write().unwrap();
if children[idx].is_none() {
let green_children = self.green.children(); let green_children = self.green.children();
let start_offset = self.start_offset() let start_offset = self.start_offset()
+ green_children[..idx] + green_children[..idx]
@ -80,6 +79,8 @@ impl RedNode {
.sum::<TextUnit>(); .sum::<TextUnit>();
let child = let child =
RedNode::new_child(green_children[idx].clone(), self.into(), start_offset, idx); RedNode::new_child(green_children[idx].clone(), self.into(), start_offset, idx);
let mut children = self.children.write();
if children[idx].is_none() {
children[idx] = Some(child) children[idx] = Some(child)
} }
Some(children[idx].as_ref().unwrap().into()) Some(children[idx].as_ref().unwrap().into())