1 instantiation of DagState
Microsoft.CodeAnalysis.CSharp (1)
Binder\DecisionDagBuilder.cs (1)
1846private static readonly ObjectPool<DagState> s_dagStatePool = new ObjectPool<DagState>(static () => new DagState());
49 references to DagState
Microsoft.CodeAnalysis.CSharp (49)
Binder\DecisionDagBuilder.cs (49)
42/// the initial state in a <see cref="DagState"/>, and then for each such state description we decide what the test 44/// represented by a <see cref="DagState"/> is a collection of partially matched cases represented by <see 45/// cref="StateForCase"/>. When we have computed <see cref="DagState"/> descriptions for all of the states, we 55private static readonly ObjectPool<PooledDictionary<DagState, DagState>> s_uniqueStatePool = 56PooledDictionary<DagState, DagState>.CreatePool(DagStateEquivalence.Instance); 742PooledDictionary<DagState, DagState> uniqueState = s_uniqueStatePool.Allocate(); 817Dictionary<DagState, DagState> uniqueState) 822using var workList = TemporaryArray<DagState>.Empty; 830DagState uniquifyState(FrozenArrayBuilder<StateForCase> cases, ImmutableDictionary<BoundDagTemp, IValueSet> remainingValues) 832var state = DagState.GetInstance(cases, remainingValues); 833if (uniqueState.TryGetValue(state, out DagState? existingState)) 887var initialState = uniquifyState(new 895DagState state = workList.RemoveLast(); 973/// Compute the <see cref="BoundDecisionDag"/> corresponding to each <see cref="DagState"/> of the given <see cref="DecisionDag"/> 974/// and store it in <see cref="DagState.Dag"/>. 982bool wasAcyclic = decisionDag.TryGetTopologicallySortedReachableStates(out ImmutableArray<DagState> sortedStates); 1006var state = sortedStates[i]; 1072DagState state, 1087DagState state, 1413DagState state, 1620public readonly DagState RootNode; 1621public DecisionDag(DagState rootNode) 1629private static void AddSuccessor(ref TemporaryArray<DagState> builder, DagState state) 1638/// <param name="result">Topologically sorted <see cref="DagState"/> nodes.</param> 1640public bool TryGetTopologicallySortedReachableStates(out ImmutableArray<DagState> result) 1657var stateIdentifierMap = PooledDictionary<DagState, int>.GetInstance(); 1680foreach (DagState state in allStates) 1846private static readonly ObjectPool<DagState> s_dagStatePool = new ObjectPool<DagState>(static () => new DagState()); 1871public DagState? TrueBranch, FalseBranch; 1881/// Created an instance of <see cref="DagState"/>. Will take ownership of <paramref name="cases"/>. That 1885public static DagState GetInstance(FrozenArrayBuilder<StateForCase> cases, ImmutableDictionary<BoundDagTemp, IValueSet> remainingValues) 1887var dagState = s_dagStatePool.Allocate(); 1943private sealed class DagStateEquivalence : IEqualityComparer<DagState> 1949public bool Equals(DagState? x, DagState? y) 1968public int GetHashCode(DagState x) 2072DagState state, 2096DagState state, 2117DagState state, 2141DagState state, 2308DagState state, 2335DagState state,