Есть ли способ, чтобы StreamReader не выполнял буферизацию?
Я пытаюсь обрабатывать выходные данные процесса, который может быть двоичным или текстовым. Результат будет выглядеть как HTTP-ответ, например.
Content-type: application/whatever
Another-header: value
text or binary data here
Что я хочу сделать, это разобрать заголовки с помощью StreamReader
, а затем либо прочитать из BaseStream
, либо StreamReader
для обработки остальной части содержимого. Вот в основном, с чего я начал:
private static readonly Regex HttpHeader = new Regex("([^:]+): *(.*)");
private void HandleOutput(StreamReader reader)
{
var headers = new NameValueCollection();
string line;
while((line = reader.ReadLine()) != null)
{
Match header = HttpHeader.Match(line);
if(header.Success)
{
headers.Add(header.Groups[1].Value, header.Groups[2].Value);
}
else
{
break;
}
}
DoStuff(reader.ReadToEnd());
}
Кажется, это мусор двоичных данных. Поэтому я изменил последнюю строку на следующее:
if(headers["Content-type"] != "text/html")
{
// reader.BaseStream.Position is not at the same place that reader
// makes it looks like it is.
// i.e. reader.Read() != reader.BaseStream.Read()
DoBinaryStuff(reader.BaseStream);
}
else
{
DoTextStuff(reader.ReadToEnd());
}
... но StreamReader буферизует ввод, поэтому reader.BaseStream находится в неправильном положении. Есть ли способ отключить StreamReader? Или я могу передать StreamReader в reset поток обратно туда, где StreamReader?