| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 |
- //
- // System.IO.TextReader
- //
- // Authors:
- // Marcin Szczepanski ([email protected])
- // Miguel de Icaza ([email protected])
- //
- using System;
- using System.Runtime.InteropServices;
- namespace System.IO {
- [Serializable]
- public abstract class TextReader : MarshalByRefObject, IDisposable {
-
- protected TextReader() { }
-
- public static readonly TextReader Null;
-
- public virtual void Close()
- {
- Dispose(true);
- }
- void System.IDisposable.Dispose()
- {
- Dispose(true);
- }
- protected virtual void Dispose( bool disposing )
- {
- return;
- }
-
- public virtual int Peek()
- {
- return -1;
- }
-
- public virtual int Read()
- {
- return -1;
- }
-
- public virtual int Read ([In, Out] char[] buffer, int index, int count)
- {
- int c, i;
-
- for (i = 0; i < count; i++) {
- if ((c = Read ()) == -1)
- return i;
- buffer [index + i] = (char)c;
- }
-
- return i;
- }
-
- public virtual int ReadBlock ([In, Out] char [] buffer, int index, int count)
- {
- int total_read_count = 0;
- int current_read_count = 0;
- do {
- current_read_count = Read (buffer, index, count);
- index += current_read_count;
- total_read_count += current_read_count;
- count -= current_read_count;
- } while (current_read_count != 0 && count > 0);
- return total_read_count;
- }
- public virtual string ReadLine()
- {
- return String.Empty;
- }
- public virtual string ReadToEnd()
- {
- return String.Empty;
- }
- public static TextReader Synchronized (TextReader reader)
- {
- if (reader == null)
- throw new ArgumentNullException ("reader is null");
- if (reader is SynchronizedReader)
- return reader;
- return new SynchronizedReader (reader);
- }
- }
- //
- // Synchronized Reader implementation, used internally.
- //
- [Serializable]
- internal class SynchronizedReader : TextReader {
- TextReader reader;
-
- public SynchronizedReader (TextReader reader)
- {
- this.reader = reader;
- }
- public override void Close ()
- {
- lock (this){
- reader.Close ();
- }
- }
- public override int Peek ()
- {
- lock (this){
- return reader.Peek ();
- }
- }
- public override int ReadBlock (char [] buffer, int index, int count)
- {
- lock (this){
- return reader.ReadBlock (buffer, index, count);
- }
- }
- public override string ReadLine ()
- {
- lock (this){
- return reader.ReadLine ();
- }
- }
- public override string ReadToEnd ()
- {
- lock (this){
- return reader.ReadToEnd ();
- }
- }
- #region Read Methods
- public override int Read ()
- {
- lock (this){
- return reader.Read ();
- }
- }
- public override int Read (char [] buffer, int index, int count)
- {
- lock (this){
- return reader.Read (buffer, index, count);
- }
- }
- #endregion
-
- }
- }
|