internal void DrainData(TdsParserStateObject stateObj)
{
try
{
SqlDataReader.SharedState sharedState = stateObj._readerState;
if (sharedState != null && sharedState._dataReady)
{
var metadata = stateObj._cleanupMetaData;
if (stateObj._partialHeaderBytesRead > 0)
{
if (!stateObj.TryProcessHeader())
{
throw SQL.SynchronousCallMayNotPend();
}
}
if (0 == sharedState._nextColumnHeaderToRead)
{
// i. user called read but didn't fetch anything
if (!stateObj.Parser.TrySkipRow(stateObj._cleanupMetaData, stateObj))
{
throw SQL.SynchronousCallMayNotPend();
}
}
else
{
// iia. if we still have bytes left from a partially read column, skip
if (sharedState._nextColumnDataToRead < sharedState._nextColumnHeaderToRead)
{
if ((sharedState._nextColumnHeaderToRead > 0) && (metadata[sharedState._nextColumnHeaderToRead - 1].metaType.IsPlp))
{
if (stateObj._longlen != 0)
{
ulong ignored;
if (!TrySkipPlpValue(ulong.MaxValue, stateObj, out ignored))
{
throw SQL.SynchronousCallMayNotPend();
}
}
}
else if (0 < sharedState._columnDataBytesRemaining)
{
if (!stateObj.TrySkipLongBytes(sharedState._columnDataBytesRemaining))
{
throw SQL.SynchronousCallMayNotPend();
}
}
}
// Read the remaining values off the wire for this row
if (!stateObj.Parser.TrySkipRow(metadata, sharedState._nextColumnHeaderToRead, stateObj))
{
throw SQL.SynchronousCallMayNotPend();
}
}
}
Run(RunBehavior.Clean, null, null, null, stateObj);
}
catch
{
_connHandler.DoomThisConnection();
throw;
}
}