Merge pull request #1998 from ethcore/bloom_optimization

small blooms optimization
This commit is contained in:
Robert Habermeier 2016-08-24 20:39:39 +02:00 committed by GitHub
commit d47361270a

View File

@ -995,8 +995,13 @@ impl BlockChain {
let log_blooms = match info.location { let log_blooms = match info.location {
BlockLocation::Branch => HashMap::new(), BlockLocation::Branch => HashMap::new(),
BlockLocation::CanonChain => { BlockLocation::CanonChain => {
let log_bloom = header.log_bloom();
if log_bloom.is_zero() {
HashMap::new()
} else {
let chain = bc::group::BloomGroupChain::new(self.blooms_config, self); let chain = bc::group::BloomGroupChain::new(self.blooms_config, self);
chain.insert(info.number as bc::Number, Bloom::from(header.log_bloom()).into()) chain.insert(info.number as bc::Number, Bloom::from(log_bloom).into())
}
}, },
BlockLocation::BranchBecomingCanonChain(ref data) => { BlockLocation::BranchBecomingCanonChain(ref data) => {
let ancestor_number = self.block_number(&data.ancestor).unwrap(); let ancestor_number = self.block_number(&data.ancestor).unwrap();