当前位置: 首页>>代码示例>>C#>>正文


C# TextReader.Read方法代码示例

本文整理汇总了C#中TextReader.Read方法的典型用法代码示例。如果您正苦于以下问题:C# TextReader.Read方法的具体用法?C# TextReader.Read怎么用?C# TextReader.Read使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在TextReader的用法示例。


在下文中一共展示了TextReader.Read方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: CalculateIndent

		public static string CalculateIndent(TextReader code, int line, bool tabsToSpaces = false, int indentWidth = 4)
		{
			if(line < 2)
				return string.Empty;
			
			var eng = new IndentEngine(DFormattingOptions.CreateDStandard(), tabsToSpaces, indentWidth);
			
			int curLine = 1;
			const int lf = (int)'\n';
			const int cr = (int)'\r';
			int c;
			while((c = code.Read()) != -1)
			{
				if(c == lf || c == cr)
				{
					if(c == cr && code.Peek() == lf)
						code.Read();
					
					if(++curLine > line)
						break;
				}
				
				eng.Push((char)c);
			}
			
			return eng.ThisLineIndent;
		}
开发者ID:DinrusGroup,项目名称:DinrusIDE,代码行数:27,代码来源:IndentEngineWrapper.cs

示例2: CsvReader

		public CsvReader(TextReader reader, char delimiter, bool parseHeader)
		{
			if (reader == null)
			{
				throw new ArgumentNullException("reader");
			}
			_reader = reader;
			_delimiter = delimiter;
			int t;
			if ((t = _reader.Read()) != -1)
			{
				_c = t;
			}
			if ((t = _reader.Read()) != -1)
			{
				_lac = t;
			}
			if (parseHeader)
			{
				if (Read())
				{
					for (int i = 0; i < _fields.Count; i++)
					{
						_columns[_fields[i]] = i;
					}
				}
			}
		}
开发者ID:lakshithagit,项目名称:Target-Process-Plugins,代码行数:28,代码来源:CsvReader.cs

示例3: ParseText

 /// <summary> Split text of the documents into tokens</summary>
 /// <param name="reader">stream with document text
 /// </param>
 /// <returns> array of occurrences of words in thedocument
 /// </returns>
 public virtual Occurrence[] ParseText(TextReader reader)
 {
     int pos = 0;
     ArrayList list = new ArrayList();
     int ch = reader.Read();
     
     while (ch > 0)
     {
         if (Char.IsLetter((char) ch) || Char.IsDigit((char) ch))
         {
             StringBuilder buf = new StringBuilder();
             int wordPos = pos;
             do 
             {
                 pos += 1;
                 buf.Append((char) ch);
                 ch = reader.Read();
             }
             while (ch > 0 && (Char.IsLetter((char) ch) || Char.IsDigit((char) ch)));
             string word = buf.ToString().ToLower();
             if (!IsStopWord(word))
             {
                 list.Add(new Occurrence(word, wordPos, 0));
             }
         }
         else
         {
             pos += 1;
             ch = reader.Read();
         }
     }
     return (Occurrence[])list.ToArray(typeof(Occurrence));
 }
开发者ID:yan122725529,项目名称:TripRobot.Crawler,代码行数:38,代码来源:FullTextSearchHelper.cs

示例4: DeserializeArray

        static void DeserializeArray(TextReader reader, ObjectBuilder builder)
        {
            int c;
            builder.StartArray();

            while(true)
            {
                c = reader.Peek();
                if (c == -1) throw new DeserializationException("Unexpected end of stream", reader);
                if (c == ']')
                {
                    reader.Read();  // skip the ]
                    break;
                }

                _DeserializeMember(reader, builder);
                Methods.ConsumeWhiteSpace(reader);
                c = reader.Read();

                if(c == ',') continue;
                if(c == ']') break;

                if(c == -1) throw new DeserializationException("Unexpected end of stream", reader);

                throw new DeserializationException("Expected , or ], found "+(char)c, reader);
            }

            builder.EndArray();
        }
开发者ID:JamesTryand,项目名称:Jil,代码行数:29,代码来源:DynamicDeserializer.cs

示例5: RawPBM

        internal RawPBM(TextReader reader)
        {
            // Read width and height
            Width = ParseNumber(ReadToken(reader));
            Height = ParseNumber(ReadToken(reader));

            // Skip single whitespace character
            reader.Read();

            // Read raster
            InitializeRaster();
            int length = Width * Height;
            int lineLength = (Width + 7) / 8;
            for (int i = 0; i < Height; i++)
            {
                for (int j = 0; j < lineLength; j++)
                {
                    // This is wrong but i don't care
                    int vec = reader.Read();
                    if (vec == -1)
                        throw new MalformedFileException();
                    ProcessPixels(i, (j * 8), vec, PackedBits(j));
                }
            }
        }
开发者ID:vosen,项目名称:UAM.ImageProcessing,代码行数:25,代码来源:RawPBM.cs

示例6: AccumulateComment

 private string AccumulateComment(TextReader reader)
 {
     reader.Read();
     bool? escaped = null;
     StringBuilder buffer = new StringBuilder();
     while (true)
     {
         if (escaped == null)
         {
             escaped = CheckIfEscaped(reader, buffer);
         }
         if (IsClosed(reader, buffer, escaped.Value))
         {
             break;
         }
         var node = reader.Read();
         if (node == -1)
         {
             throw new InvalidOperationException("Reached end of template in the middle of a comment");
         }
         else
         {
             buffer.Append((char)node);
         }
     }
     return buffer.ToString();
 }
开发者ID:fedeneo77,项目名称:Handlebars.Net,代码行数:27,代码来源:CommentParser.cs

示例7: ReadNumber

        /// <summary>
        /// Reads a number from a text reader.
        /// </summary>
        /// <param name="input">The input to read from.</param>
        /// <returns>The number read.</returns>
        public static double ReadNumber(TextReader input)
        {
            // TODO: Check whether this is used in the parser (move to ModMaker.Lua) and make this
            //  consitent with the spec.
            StringBuilder build = new StringBuilder();

            int c = input.Peek();
            int l = c;
            bool hex = false;
            CultureInfo ci = CultureInfo.CurrentCulture;
            if (c == '0')
            {
                input.Read();
                c = input.Peek();
                if (c == 'x' || c == 'X')
                {
                    input.Read();
                    hex = true;
                }
            }

            while (c != -1 && (char.IsNumber((char)c) || (hex && ((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z'))) ||
                (!hex && (c == ci.NumberFormat.NumberDecimalSeparator[0] || c == '-' || (l != '.' && c == 'e')))))
            {
                input.Read();
                build.Append((char)c);
                l = c;
                c = input.Peek();
            }

            return double.Parse(build.ToString(), ci);
        }
开发者ID:TheModMaker,项目名称:ModMaker.Lua,代码行数:37,代码来源:NetHelpers.cs

示例8: AccumulateLiteral

 private static string AccumulateLiteral(TextReader reader, bool captureDelimiter, params char[] delimiters)
 {
     StringBuilder buffer = new StringBuilder();
     while (true)
     {
         var node = reader.Peek();
         if (node == -1)
         {
             throw new InvalidOperationException("Reached end of template before the expression was closed.");
         }
         else
         {
             if (delimiters.Contains((char)node))
             {
                 if (captureDelimiter)
                 {
                     reader.Read();
                 }
                 break;
             }
             else if ((char)node == '}')
             {
                 break;
             }
             else
             {
                 buffer.Append((char)reader.Read());
             }
         }
     }
     return buffer.ToString();
 }
开发者ID:jamisliao,项目名称:Handlebars.Net,代码行数:32,代码来源:LiteralParser.cs

示例9: Escape

 /// <summary>
 /// Escapes the characters in a String
 /// </summary>
 /// <param name="reader">the input string reader to escaping.</param>
 /// <returns>a string that has been escaped.</returns>
 public static string Escape(TextReader reader)
 {
     var sb = new StringBuilder();
     var code = -1;
     while ((code = reader.Read()) >= 0)
     {
         var ch = (char)code;
         if (ch == '<')
         {
             sb.Append(ch);
             if (reader.Peek() != -1 && ((char)reader.Peek()) == '/')
             {
                 sb.Append(@"\/");
                 reader.Read();
             }
         }
         else
         {
             string escapeChar = null;
             if (_escapeSequences.TryGetValue(ch, out escapeChar))
             {
                 sb.Append(escapeChar);
             }
             else
             {
                 sb.Append(ch);
             }
         }
     }
     return sb.ToString();
 }
开发者ID:llenroc,项目名称:HttpClient,代码行数:36,代码来源:StringEscapeUtils.cs

示例10: SeekLine

        /// <summary>
        /// Seeks the first character of a specified line in the text stream.
        /// </summary>
        /// <param name="reader">The reader.</param>
        /// <param name="line">Line number. The current position is assumed to be line #1.</param>
        /// <returns>
        /// Returns <c>true</c> if the line is found, <b>false</b> otherwise.
        /// </returns>
        public static bool SeekLine(TextReader reader, int line)
        {
            ContractUtils.RequiresNotNull(reader, "reader");
            if (line < 1) throw new ArgumentOutOfRangeException("line");
            if (line == 1) return true;

            int current_line = 1;

            for (; ; ) {
                int c = reader.Read();

                if (c == '\r') {
                    if (reader.Peek() == '\n') {
                        reader.Read();
                    }

                    current_line++;
                    if (current_line == line) return true;

                } else if (c == '\n') {
                    current_line++;
                    if (current_line == line) return true;
                } else if (c == -1) {
                    return false;
                }
            }
        }
开发者ID:TerabyteX,项目名称:main,代码行数:35,代码来源:IOUtils.cs

示例11: AccumulatePartial

 private string AccumulatePartial(TextReader reader)
 {
     StringBuilder buffer = new StringBuilder();
     buffer.Append(">");
     do
     {
         reader.Read();
     }
     while(char.IsWhiteSpace((char)reader.Peek()));
     while(true)
     {
         var peek = (char)reader.Peek();
         if (peek == '}' || peek == '~' || char.IsWhiteSpace(peek))
         {
             break;
         }
         var node = reader.Read();
         if (node == -1)
         {
             throw new InvalidOperationException("Reached end of template before the expression was closed.");
         }
         else
         {
             buffer.Append((char)node);
         }
     }
     return buffer.ToString();
 }
开发者ID:jamisliao,项目名称:Handlebars.Net,代码行数:28,代码来源:PartialParser.cs

示例12: Tokenize

        /// <summary>
        /// Processes text from TextReader and splits it into tokens.
        /// </summary>
        /// <param name="reader">The TextReader to read string from</param>
        /// <returns>The collection parsed tokens of the input string</returns>
        public static IEnumerable<WktToken> Tokenize(TextReader reader)
        {
            StringBuilder stringBuffer = new StringBuilder();

            if (reader.Peek() == -1) {
                yield break;
            }

            char ch = (char)reader.Read();
            stringBuffer.Append(ch);
            TokenType lastToken = WktTokenizer.GetTokenType(ch);

            while (reader.Peek() != -1) {
                ch = (char)reader.Read();
                TokenType token = WktTokenizer.GetTokenType(ch);

                // tokens COMMA, LEFT_PARENTHESIS and RIGHT_PARENTHESIS can not be grupped together
                if ((token != lastToken) || token == TokenType.COMMA || token == TokenType.LEFT_PARENTHESIS || token == TokenType.RIGHT_PARENTHESIS) {
                    yield return new WktToken() { Type = lastToken, Value = stringBuffer.ToString() };

                    stringBuffer.Clear();
                    lastToken = token;
                }

                stringBuffer.Append(ch);
            }

            yield return new WktToken() { Type = lastToken, Value = stringBuffer.ToString() };
        }
开发者ID:najira,项目名称:spatiallite-net,代码行数:34,代码来源:WktTokenizer.cs

示例13: Parse

 public static DateTime Parse(TextReader reader, int context)
 {
     var cur = reader.Read();
     if (cur == ',' || cur == ')')
         return DateTime.MinValue;
     var dt = ParseTimestamp(reader, context);
     reader.Read();
     return dt;
 }
开发者ID:rinmalavi,项目名称:revenj,代码行数:9,代码来源:TimestampConverter.cs

示例14: CorrectIndent

		public static void CorrectIndent(TextReader code, int startOffset, int endOffset, Action<int, int, string> documentReplace, DFormattingOptions options = null, ITextEditorOptions textStyle = null, bool formatLastLine = true)
		{
			textStyle = textStyle ?? TextEditorOptions.Default;
			
			var eng = new IndentEngine(options ?? DFormattingOptions.CreateDStandard(), textStyle.TabsToSpaces, textStyle.IndentSize, textStyle.KeepAlignmentSpaces);
			var replaceActions = new List<DFormattingVisitor.TextReplaceAction>();
			
			int originalIndent = 0;
			bool hadLineBreak = true;
			
			int n = 0;
			for (int i = 0; i <= endOffset && (n = code.Read()) != -1; i++)
			{
				if(n == '\r' || n == '\n')
				{
					if (i >= startOffset && !eng.LineBeganInsideString)
						replaceActions.Add(new DFormattingVisitor.TextReplaceAction(eng.Position - eng.LineOffset, originalIndent, eng.ThisLineIndent));
					
					hadLineBreak = true;
					originalIndent = 0;

					if (code.Peek() == '\n')
					{
						eng.Push((char)code.Read());
						i++;
					}
				}
				else if(hadLineBreak)
				{
					if(n == ' ' || n== '\t')
						originalIndent++;
					else
						hadLineBreak = false;

					// If there's code left, format the last line of the selection either
					if (i == endOffset && formatLastLine)
						endOffset++;
				}

				eng.Push((char)n);
			}

			// Also indent the last line if we're at the EOF.
			if (code.Peek() == -1 || (formatLastLine && n != '\r' && n != '\n'))
			{
				if(!eng.LineBeganInsideString)
					replaceActions.Add(new DFormattingVisitor.TextReplaceAction(eng.Position - eng.LineOffset, originalIndent, eng.ThisLineIndent));
			}
			
			// Perform replacements from the back of the document to the front - to ensure offset consistency
			for(int k = replaceActions.Count - 1; k>=0; k--)
			{
				var rep = replaceActions[k];
				if(rep.RemovalLength > 0 || rep.NewText.Length != 0)
					documentReplace(rep.Offset, rep.RemovalLength, rep.NewText);
			}
		}
开发者ID:DinrusGroup,项目名称:DinrusIDE,代码行数:57,代码来源:IndentEngineWrapper.cs

示例15: ParseImpl

 public static object ParseImpl(TextReader reader, GRGEN_LIBGR.AttributeType attrType, GRGEN_LIBGR.IGraph graph)
 {
     char lookahead = (char)reader.Peek();
     if(lookahead == 'o')
     {
         reader.Read(); // eat 'o'
         return new Own();
     }
     else if(lookahead == 'p')
     {
         reader.Read(); // eat 'p'
         StringBuilder sb = new StringBuilder();
         while(reader.Peek() != ',' && reader.Peek() != ')') // attributes are separated by , a node/edge terminated by ) in .grs
             sb.Append((char)reader.Read()); // eat non ',', ')'
         OwnPown op = new OwnPown();
         op.ehe = sb.ToString();
         return op;
     }
     else if(lookahead == 'h')
     {
         reader.Read(); // eat 'h'
         StringBuilder sb = new StringBuilder();
         while(reader.Peek() != ';')
             sb.Append((char)reader.Read()); // eat non ';'
         string ehe = sb.ToString();
         sb.Length = 0;
         reader.Read(); // eat ';'
         while(reader.Peek() != ',' && reader.Peek() != ')') // attributes are separated by , a node/edge terminated by ) in .grs
             sb.Append((char)reader.Read()); // eat non ',',')'
         OwnPownHome oph = new OwnPownHome();
         oph.ehe = ehe;
         oph.aha = sb.ToString();
         return oph;
     }
     else
     {
         if(reader.Peek() == 'n')
         {
             reader.Read();
             if(reader.Peek() == 'u')
             {
                 reader.Read();
                 if(reader.Peek() == 'l')
                 {
                     reader.Read();
                     if(reader.Peek() == 'l')
                     {
                         reader.Read();
                         return null;
                     }
                 }
             }
         }
         throw new Exception("parsing failure");
     }
 }
开发者ID:jblomer,项目名称:GrGen.NET,代码行数:56,代码来源:ExternalAttributeEvaluationModelExternalFunctionsImpl.cs


注:本文中的TextReader.Read方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。