本文整理汇总了C#中Stack.Select方法的典型用法代码示例。如果您正苦于以下问题:C# Stack.Select方法的具体用法?C# Stack.Select怎么用?C# Stack.Select使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Stack
的用法示例。
在下文中一共展示了Stack.Select方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: GetValue
public IItem GetValue(IDictionary<string, IItem> variables) {
var stack = new Stack<object>();
int i = 0;
try {
for (; i < tokens.Count; i++) {
var token = tokens[i];
double d;
if (TryParse(token, out d)) {
stack.Push(d);
} else if (token.StartsWith("\"")) {
stack.Push(GetVariableValue(variables, token.Substring(1, token.Length - 2).Replace("\\\"", "\"")));
} else if (token.StartsWith("'")) {
stack.Push(token.Substring(1, token.Length - 2).Replace("\\'", "'"));
} else {
Apply(token, stack, variables);
}
}
} catch (Exception x) {
throw new Exception(string.Format(
"Calculation of '{1}'{0}failed at token #{2}: {3} {0}current stack is: {0}{4}", Environment.NewLine,
Formula, i, TokenWithContext(tokens, i, 3),
string.Join(Environment.NewLine, stack.Select(AsString))),
x);
}
if (stack.Count != 1)
throw new Exception(
string.Format("Invalid final evaluation stack size {0} (should be 1) in formula '{1}'",
stack.Count, Formula));
var result = stack.Pop();
if (result is string) return new StringValue((string)result);
if (result is int) return new IntValue((int)result);
if (result is double) return new DoubleValue((double)result);
if (result is bool) return new BoolValue((bool)result);
return null;
}
示例2: CalculateName
public static string CalculateName(DirectoryInfo root, DirectoryInfo folder)
{
if (root.Root.FullName != folder.Root.FullName)
throw new InvalidOperationException("Unrelated directories.");
Stack<DirectoryInfo> rootList = new Stack<DirectoryInfo>();
while (root.FullName != root.Root.FullName)
{
rootList.Push(root);
root = root.Parent;
}
Stack<DirectoryInfo> itemList = new Stack<DirectoryInfo>();
while (folder.FullName != folder.Root.FullName)
{
itemList.Push(folder);
folder = folder.Parent;
}
while (rootList.Count != 0 && itemList.Count != 0 && rootList.Peek().Name == itemList.Peek().Name)
{
rootList.Pop();
itemList.Pop();
}
if (rootList.Count != 0)
throw new InvalidOperationException("Item is not contained in root.");
if (itemList.Count == 0)
return null;
return String.Join("/", itemList.Select(item => item.Name));
}
示例3: CheckMax
private void CheckMax(Stack<Coordinate> coordinates)
{
int max = 1;
var values = coordinates.Select(c => _data[c.X, c.Y]);
values.ToList().ForEach(i => max *= i);
if (max > Max) {
Max = max;
MaxCoor.Clear();
MaxCoor.AddRange(coordinates.Reverse());
}
}
示例4: getAllAnagrams
private static void getAllAnagrams(string s, Stack<char> st, ref Node n)
{
if (s.Length <= 0)
{
// End of tree branch - flatten the stack and add it to Anagrams list.
allAnagramsList.Add(st.Select(q => q).ToArray());
}
for (int i = 0; i < s.Length; i++)
{
if (n != null && !n.nodeList.Exists(x => x.value == s[i]))
{
Node newnode = new Node();
newnode.value = s[i];
st.Push(s[i]);
n.nodeList.Add(newnode);
string temp = s.Remove(i, 1);
getAllAnagrams(temp, st, ref newnode);
st.Pop();
}
}
}
示例5: Tokenize
//.........这里部分代码省略.........
//open group
var token = m.Value.TrimStart('{').TrimEnd('}').TrimStart('#').Trim();
if (scopestack.Any() && scopestack.Peek().Item1 == token)
{
yield return new TokenPair(TokenType.ElementClose, Validated(token, templateString, m.Index, ref lines, ref parseErrors));
}
else
{
scopestack.Push(Tuple.Create(token, m.Index));
}
yield return new TokenPair(TokenType.ElementOpen, Validated(token, templateString, m.Index, ref lines, ref parseErrors));
}
else if (m.Value.StartsWith("{{^"))
{
//open inverted group
var token = m.Value.TrimStart('{').TrimEnd('}').TrimStart('^').Trim();
if (scopestack.Any() && scopestack.Peek().Item1 == token)
{
yield return new TokenPair(TokenType.ElementClose, Validated(token, templateString, m.Index, ref lines, ref parseErrors));
}
else
{
scopestack.Push(Tuple.Create(token, m.Index));
}
yield return new TokenPair(TokenType.InvertedElementOpen, Validated(token, templateString, m.Index, ref lines, ref parseErrors));
}
else if (m.Value.StartsWith("{{/"))
{
var token = m.Value.TrimStart('{').TrimEnd('}').TrimStart('/').Trim();
//close group
if (scopestack.Any() && scopestack.Peek().Item1 == token)
{
scopestack.Pop();
yield return new TokenPair(TokenType.ElementClose, Validated(token, templateString, m.Index, ref lines, ref parseErrors));
}
else
{
var location = HumanizeCharacterLocation(templateString, m.Index, ref lines);
parseErrors.Add(new IndexedParseException(location, "It appears that open and closing elements are mismatched."));
}
}
else if (m.Value.StartsWith("{{{") | m.Value.StartsWith("{{&"))
{
//escaped single element
var token = m.Value.TrimStart('{').TrimEnd('}').TrimStart('&').Trim();
yield return new TokenPair(TokenType.UnescapedSingleValue, Validated(token, templateString, m.Index, ref lines, ref parseErrors));
}
else if (m.Value.StartsWith("{{!"))
{
//it's a comment drop this on the floor, no need to even yield it.
}
else
{
//unsingle value.
var token = m.Value.TrimStart('{').TrimEnd('}').Trim();
yield return new TokenPair(TokenType.EscapedSingleValue, Validated(token, templateString, m.Index, ref lines, ref parseErrors));
}
//move forward in the string.
idx = m.Index + m.Length;
}
if (idx < templateString.Length)
{
yield return new TokenPair(TokenType.Content, templateString.Substring(idx));
}
#region Assert that any scopes opened must be closed.
if (scopestack.Any())
{
var scopes = scopestack.Select(k =>
{
var value = k.Item1.Trim('{', '#', '}');
if (value.StartsWith("each "))
{
value = value.Substring(5);
}
return new { scope = value, location = HumanizeCharacterLocation(templateString, k.Item2, ref lines) };
}).Reverse()
.ToArray();
foreach (var unclosedScope in scopes)
{
//var line = FindLineForLocation(templateString, m.Index, ref lines);
parseErrors.Add(new IndexedParseException(unclosedScope.location,
"A scope block to the following path was opened but not closed: '{0}', please close it using the appropriate syntax.",
unclosedScope.scope));
}
}
#endregion
//We want to throw an aggregate template exception, but in due time.
if (parseErrors.Any())
{
var innerExceptions = parseErrors.OrderBy(k => k.LineNumber).ThenBy(k => k.CharacterOnLine).ToArray();
throw new AggregateException(innerExceptions);
}
yield break;
}
示例6: Sort
public IEnumerable<IBuildStep> Sort(IEnumerable<IBuildStep> buildSteps)
{
List<Node> nodeGraph = buildSteps.Select(buildStep => new Node(buildStep)).ToList();
foreach (var node in nodeGraph)
{
var depends = (DependsOnAttribute[])Attribute.GetCustomAttributes(node.BuildStep.GetType(), typeof(DependsOnAttribute));
var dependNodes = nodeGraph.Where(n => depends.Any(d => d.DependedOnStep == n.BuildStep.GetType()));
var edges = dependNodes.Select(n => new Edge(node, n)).ToArray();
node.OutgoingEdges.AddRange(edges);
foreach (var edge in edges)
edge.DestinationNode.IncomingEdges.Add(edge);
}
var result = new Stack<Node>();
var sourceNodes = new Stack<Node>(nodeGraph.Where(n => !n.IncomingEdges.Any()));
while (sourceNodes.Count > 0)
{
var sourceNode = sourceNodes.Pop();
result.Push(sourceNode);
for (int i = sourceNode.OutgoingEdges.Count - 1; i >= 0; i--)
{
var edge = sourceNode.OutgoingEdges[i];
edge.Remove();
if (!edge.DestinationNode.IncomingEdges.Any())
sourceNodes.Push(edge.DestinationNode);
}
}
if (nodeGraph.SelectMany(n => n.IncomingEdges).Any())
throw new CircularDependencyException();
return result.Select(n => n.BuildStep);
}
示例7: GetAllCombinationsWithSumS
private static void GetAllCombinationsWithSumS(TreeNode<int> start, Stack<TreeNode<int>> stack, int currentSum, List<List<int>> res, int sum)
{
stack.Push(start);
currentSum += start.Value;
if (start.Children.Count == 0)
{
if (currentSum == sum)
{
var r = stack.Select(x => x.Value).ToList();
res.Add(r);
}
return;
}
foreach (var child in start.Children)
{
GetAllCombinationsWithSumS(child, stack, currentSum, res, sum);
stack.Pop();
}
}
示例8: sanitizer
public static SanitizeResult sanitizer(String html, Regex allowedTags, Regex forbiddenTags)
{
SanitizeResult ret = new SanitizeResult();
Stack<String> openTags = new Stack<string>();
if (String.IsNullOrEmpty(html))
return ret;
List<String> tokens = tokenize(html);
// ------------------- LOOP for every token --------------------------
for (int i = 0; i < tokens.Count; i++)
{
String token = tokens[i];
bool isAcceptedToken = false;
Match startMatcher = tagStartPattern.Match(token);
Match endMatcher = tagClosePattern.Match(token);
//-------------------------------------------------------------------------------- COMMENT <!-- ......... -->
if (commentPattern.Match(token).Success)
{
ret.val = ret.val + token + (token.EndsWith("-->") ? "" : "-->");
ret.invalidTags.Add(token + (token.EndsWith("-->") ? "" : "-->"));
continue;
//-------------------------------------------------------------------------------- OPEN TAG <tag .........>
}
else if (startMatcher.Success)
{
//tag name extraction
String tag = startMatcher.Groups[1].Value.ToLower();
//----------------------------------------------------- FORBIDDEN TAG <script .........>
if (forbiddenTags.Match(tag).Success)
{
ret.invalidTags.Add("<" + tag + ">");
continue;
// -------------------------------------------------- WELL KNOWN TAG
}
else if (allowedTags.Match(tag).Success)
{
String cleanToken = "<" + tag;
String tokenBody = startMatcher.Groups[2].Value;
//first test table consistency
//table tbody tfoot thead th tr td
if ("thead".Equals(tag) || "tbody".Equals(tag) || "tfoot".Equals(tag) || "tr".Equals(tag))
{
if (openTags.Select(t => t == "table").Count() <= 0)
{
ret.invalidTags.Add("<" + tag + ">");
continue;
}
}
else if ("td".Equals(tag) || "th".Equals(tag))
{
if (openTags.Count(t => t == "tr") <= 0)
{
ret.invalidTags.Add("<" + tag + ">");
continue;
}
}
// then test properties
//Match attributes = attributesPattern.Match(tokenBody);
var attributes = attributesPattern.Matches(tokenBody);
bool foundURL = false; // URL flag
foreach (Match attribute in attributes)
//while (attributes.find())
{
String attr = attribute.Groups[1].Value.ToLower();
String val = attribute.Groups[2].Value;
// we will accept href in case of <A>
if ("a".Equals(tag) && "href".Equals(attr))
{ // <a href="......">
try
{
var url = new Uri(val);
if (url.Scheme == Uri.UriSchemeHttp || url.Scheme == Uri.UriSchemeHttps || url.Scheme == Uri.UriSchemeMailto)
{
foundURL = true;
}
else
{
ret.invalidTags.Add(attr + " " + val);
val = "";
}
}
catch
{
ret.invalidTags.Add(attr + " " + val);
//.........这里部分代码省略.........
示例9: ParseInLineVariableOrMetadata
//.........这里部分代码省略.........
isProblem = true;
changedLanguage = true;
}
}
else
{
errorId = data.ErrorList.Count;
data.ErrorList.Add(
Markdown.GenerateError(
Language.Message("BadLinkOrMissingMarkdownFile", pathToLinkedFile, variableName),
MessageClass.Error,
Markdown.Unescape(OnErrorStringToUseForMatch),
errorId,
data));
isProblem = true;
outString = OnErrorStringToUseForMatch;
}
}
if (linkedFileDir.Exists && linkedFileDir.GetFiles(string.Format("*.{0}.udn", languageForFile)).Length > 0)
{
currentFile = linkedFileDir.GetFiles(string.Format("*.{0}.udn", languageForFile))[0];
}
}
// Cycle detection mechanism. First check if there was request for that variable in the visited stack.
var currentVisitedVariableTuple = new Tuple<string, string>(currentFile.FullName, variableName);
if (visitedVariables != null && visitedVariables.Contains(currentVisitedVariableTuple))
{
// cycle detected
visitedVariables.Push(currentVisitedVariableTuple);
string visitedVariablesMessage = string.Join(", ", visitedVariables.Select(
(v) =>
{
return string.Format("[{0}, {1}]", v.Item1, v.Item2);
}));
visitedVariables.Pop();
data.ErrorList.Add(
Markdown.GenerateError(Language.Message("CycleDetectedInVariableRefs", visitedVariablesMessage), MessageClass.Error,
"", data.ErrorList.Count, data));
return "";
}
if (!data.ProcessedDocumentCache.TryGetLinkedFileVariable(currentFile, variableName, out outString))
{
if (doc.PerformStrictConversion())
{
//error
errorId = data.ErrorList.Count;
data.ErrorList.Add(
Markdown.GenerateError(
Language.Message("VariableOrMetadataNotFoundInFile", variableName, currentFile.FullName),
MessageClass.Error,
OnErrorStringToUseForMatch,
errorId,
data));
isProblem = true;
}
outString = OnErrorStringToUseForMatch.Replace("%", "%");
}
else
示例10: NameFromStack
private static string NameFromStack(Stack<IAnalysisItemView> stack) {
return string.Join(".", stack.Select(av => av.Name));
}
示例11: Run
public ITestResult Run(IIntent intent, ITestProvider provider)
{
if (provider.Ignored)
return _resultFactory.CreateIgnoredTestResult(provider);
_listener.OnTestStarted(intent);
IOutputRecording outputRecording;
var operationResults = new List<IOperationResult>();
var cleanupProviderStack = new Stack<IOperationProvider>();
var stopWatch = Stopwatch.StartNew();
using (outputRecording = _resultFactory.CreateOutputRecording())
{
// TODO: Repetition with ContextRunner
foreach (var operationProvider in provider.OperationProviders)
{
Trace.Assert(
!cleanupProviderStack.Contains(operationProvider) || operationProvider == cleanupProviderStack.Pop(),
string.Format("Cleanup ({0}) is not in order to setup.", operationProvider.Action));
var operationResult = _operationRunner.Run(operationProvider);
operationResults.Add(operationResult);
if (operationResult.State == State.Failed && operationResult.Type != OperationType.Assertion)
break;
if (operationProvider.CleanupProvider != null)
cleanupProviderStack.Push(operationProvider.CleanupProvider);
}
Trace.Assert(
!cleanupProviderStack.Any() || operationResults.Any(x => x.State == State.Failed),
"Either cleanup stack must be empty, or any result must have failed.");
operationResults.AddRange(cleanupProviderStack.Select(_operationRunner.Run));
}
var result = _resultFactory.CreateTestResult(provider, stopWatch.Elapsed, outputRecording, operationResults);
_listener.OnTestFinished(result);
return result;
}
示例12: ParseIntegerRange
private IEnumerable<Node> ParseIntegerRange()
{
var intRes = new Stack<int>();
var token = _tokens.Peek();
while (!token.Lexeme.Equals(";"))
{
token = _tokens.Dequeue();
var lexeme = token.Lexeme;
if (",".Equals(lexeme))
{
if (!intRes.Any())
{
_errors.Add(
new ParseError(
"Expected integer literal before ',' in reserved range ",
token));
return new List<Node>();
}
token = _tokens.Peek();
continue;
}
if (_parser.IsDecimalLiteral(lexeme))
{
intRes.Push(int.Parse(lexeme));
token = _tokens.Peek();
continue;
}
if (!"to".Equals(lexeme))
{
token = _tokens.Peek();
continue;
}
// So now we are looking ahead at the token after 'to', so we have something like '9 to 11'
if (!intRes.Any()) // In the case that we found a 'to' but haven't yet found an integer
{
_errors.Add(
new ParseError(
"Expected integer literal before 'to' in reserved range ",
token));
return new List<Node>();
}
var startRangeAt = intRes.Pop(); // Go get the last integer read, e.g. 9
var nextToken = _tokens.Peek(); // Look ahead for the next integer, e.g. 11
if (!_parser.IsDecimalLiteral(nextToken.Lexeme)) // If the next token isn't an integer create Error
{
_errors.Add(
new ParseError(
"Expected integer literal after 'to' in reserved range ",
nextToken));
return new List<Node>();
}
// If we don't have an error go ahead and remove the token and use it to find the end range.
nextToken = _tokens.Dequeue();
var endRangeAt = int.Parse(nextToken.Lexeme);
// Now push all the integers in the range onto the stack.
var rangeLength = endRangeAt - startRangeAt + 1;
foreach (var elem in Enumerable.Range(startRangeAt, rangeLength))
{
intRes.Push(elem);
}
// If we've got this far, set the token for the While comparison to the next.
token = _tokens.Peek();
}
// Now that we've hit an Endline or ';' terminator, return.
return intRes.Select(t => new Node(NodeType.IntegerLiteral, t.ToString())).Reverse();
}
示例13: ConstructsFrames
private static void ConstructsFrames(RunElementTreeNode thisNode, Stack<RunElementTreeNode> stack, Collection<RunFrame> frames, AbstractRunFrameFactory runFrameFactory)
{
if (thisNode == null)
{
throw new System.ArgumentNullException("thisNode");
}
if (stack == null)
{
throw new ArgumentNullException("stack");
}
if (frames == null)
{
throw new ArgumentNullException("frames");
}
if (runFrameFactory == null)
{
throw new ArgumentNullException("runFrameFactory");
}
stack.Push(thisNode);
if (thisNode.FirstChild == null)
{
frames.Add(runFrameFactory.CreateFrame(stack.Select(node => node.Element)));
}
else
{
ConstructsFrames(thisNode.FirstChild, stack, frames, runFrameFactory);
}
stack.Pop();
if (thisNode.Next != null)
{
ConstructsFrames(thisNode.Next, stack, frames, runFrameFactory);
}
}
示例14: FindCircularDependencies
public List<CircularDependency> FindCircularDependencies()
{
if(NodeDependencies.Count == 0)
return null;
var circularDependencies = new List<CircularDependency>();
var stack = new Stack<NodeInfo>();
stack.Push(new NodeInfo(this));
while(stack.Any())
{
var current = stack.Peek().GetNextDependency();
if(current != null)
{
if(current.Node == this)
{
var nodes = stack.Select(info => info.Node);
circularDependencies.Add(new CircularDependency(nodes));
}
else
{
bool visited = stack.Any(info => info.Node == current.Node);
if(!visited)
stack.Push(current);
}
}
else
{
stack.Pop();
}
}
return circularDependencies;
}
示例15: GetRelativePath
/// <summary>
/// Build the relative path in the same format that ZipArchive uses
/// </summary>
private static string GetRelativePath(DirectoryInfo root, FileInfo file)
{
var parents = new Stack<DirectoryInfo>();
var parent = file.Directory;
while (parent != null
&& !StringComparer.OrdinalIgnoreCase.Equals(parent.FullName, root.FullName))
{
parents.Push(parent);
parent = parent.Parent;
}
if (parent == null)
{
// the given file path does not appear under root
throw new FileNotFoundException(file.FullName);
}
var parts = parents.Select(d => d.Name).Concat(new string[] { file.Name });
return String.Join("/", parts);
}