Skip to content

Commit

Permalink
Simplify
Browse files Browse the repository at this point in the history
  • Loading branch information
slozier committed Jan 2, 2023
1 parent d32120c commit 9996933
Showing 1 changed file with 17 additions and 29 deletions.
46 changes: 17 additions & 29 deletions Src/IronPython/Runtime/CommonDictionaryStorage.cs
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ namespace IronPython.Runtime {
/// Mutations to the dictionary involves a simple locking strategy of
/// locking on the DictionaryStorage object to ensure that only one
/// mutation happens at a time.
///
///
/// Reads against the dictionary happen lock free. When the dictionary is mutated
/// it is either adding or removing buckets in a thread-safe manner so that the readers
/// will either see a consistent picture as if the read occured before or after the mutation.
Expand Down Expand Up @@ -161,11 +161,12 @@ public void AddNoLock(object key, object value) {
}

private void AddOne(object key, object value) {
GetHash(key, out var hc, out var eqFunc);
if (AddWorker(_indices, _buckets, new Bucket(key, value, hc), eqFunc)) {
Debug.Assert(_keyType == HeterogeneousType || key?.GetType() == _keyType);
var hc = _hashFunc(key) & int.MaxValue;
if (AddWorker(_indices, _buckets, new Bucket(key, value, hc), _eqFunc)) {
if (_count >= (_indices.Length * Load)) {
// grow the hash table
EnsureSize((int)(_indices.Length / Load) * ResizeMultiplier, eqFunc);
EnsureSize((int)(_indices.Length / Load) * ResizeMultiplier, _eqFunc);
}
}
}
Expand Down Expand Up @@ -298,7 +299,9 @@ private static KeyValuePair<int, int> LookupIndex(int[] indices, List<Bucket> bu
}

// keep walking
index = ProbeNext(indices, index);
if (++index == indices.Length) {
index = 0;
}

// if we ended up doing a full scan, then this means the key is not already in use and there are
// only recycled buckets available -- nothing more to probe
Expand Down Expand Up @@ -329,15 +332,6 @@ private bool AddWorker(int[] indices, List<Bucket> buckets, Bucket bucket, Func<
return true;
}

private static int ProbeNext(int[] indices, int index) {
// probe to next bucket
index++;
if (index == indices.Length) {
index = 0;
}
return index;
}

/// <summary>
/// Removes an entry from the dictionary and returns true if the
/// entry was removed or false.
Expand Down Expand Up @@ -389,10 +383,7 @@ private void GetHash(object key, out int hc, out Func<object, object, bool> eqFu

private bool TryRemoveNoLock(object key, out object value) {
GetHash(key, out var hc, out var eqFunc);
return TryRemoveNoLock(key, hc, eqFunc, out value);
}

private bool TryRemoveNoLock(object key, int hc, Func<object, object, bool> eqFunc, out object value) {
if (_indices == null) {
value = null;
return false;
Expand Down Expand Up @@ -445,22 +436,19 @@ public override bool TryGetValue(object key, out object value)
private bool TryGetValue(int[] indices, List<Bucket> buckets, object key, out object value) {
if (_count > 0 && indices != null) {
GetHash(key, out var hc, out var eqFunc);
return TryGetValue(indices, buckets, key, hc, eqFunc, out value);
}

value = null;
return false;
}
var pair = LookupIndex(indices, buckets, key, hc, eqFunc);
if (pair.Value < 0) {
value = null;
return false;
}

private static bool TryGetValue(int[] indices, List<Bucket> buckets, object key, int hc, Func<object, object, bool> eqFunc, out object value) {
var pair = LookupIndex(indices, buckets, key, hc, eqFunc);
if (pair.Value < 0) {
value = null;
return false;
value = buckets[pair.Value].Value;
return true;
}

value = buckets[pair.Value].Value;
return true;
value = null;
return false;
}

/// <summary>
Expand Down

0 comments on commit 9996933

Please sign in to comment.