You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			199 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			199 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| //------------------------------------------------------------------------------
 | |
| // <copyright file="SqlStatistics.cs" company="Microsoft">
 | |
| //     Copyright (c) Microsoft Corporation.  All rights reserved.
 | |
| // </copyright>
 | |
| // <owner current="true" primary="true">[....]</owner>
 | |
| // <owner current="true" primary="false">[....]</owner>
 | |
| //------------------------------------------------------------------------------
 | |
| 
 | |
| 
 | |
| using System;
 | |
| using System.Collections;
 | |
| using System.Data.Common;
 | |
| using System.Diagnostics;
 | |
| 
 | |
| 
 | |
| namespace System.Data.SqlClient
 | |
| {
 | |
|     internal sealed class SqlStatistics {
 | |
| 
 | |
|         static internal SqlStatistics StartTimer(SqlStatistics statistics) {
 | |
|             if ((null != statistics) && !statistics.RequestExecutionTimer()) {
 | |
|                 // we're re-entrant -- don't bother.
 | |
|                 statistics = null;
 | |
|             }
 | |
|             return statistics;
 | |
|         }
 | |
| 
 | |
|         static internal void StopTimer(SqlStatistics statistics) {
 | |
|             if (null != statistics) {
 | |
|                 statistics.ReleaseAndUpdateExecutionTimer();
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         // internal values that are not exposed through properties
 | |
|         internal long _closeTimestamp;
 | |
|         internal long _openTimestamp;
 | |
|         internal long _startExecutionTimestamp;
 | |
|         internal long _startFetchTimestamp;
 | |
|         internal long _startNetworkServerTimestamp;
 | |
| 
 | |
|         // internal values that are exposed through properties
 | |
|         internal long _buffersReceived;
 | |
|         internal long _buffersSent;
 | |
|         internal long _bytesReceived;
 | |
|         internal long _bytesSent;
 | |
|         internal long _connectionTime;
 | |
|         internal long _cursorOpens;
 | |
|         internal long _executionTime;
 | |
|         internal long _iduCount;
 | |
|         internal long _iduRows;
 | |
|         internal long _networkServerTime;
 | |
|         internal long _preparedExecs;
 | |
|         internal long _prepares;
 | |
|         internal long _selectCount;
 | |
|         internal long _selectRows;
 | |
|         internal long _serverRoundtrips;
 | |
|         internal long _sumResultSets;
 | |
|         internal long _transactions;
 | |
|         internal long _unpreparedExecs;
 | |
| 
 | |
|         // these flags are required if statistics is turned on/off in the middle of command execution
 | |
|         private bool _waitForDoneAfterRow;
 | |
|         private bool _waitForReply;
 | |
| 
 | |
| 
 | |
|         internal bool WaitForDoneAfterRow {
 | |
|             get {
 | |
|                 return _waitForDoneAfterRow;
 | |
|             }
 | |
|             set {
 | |
|                 _waitForDoneAfterRow = value;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         internal bool WaitForReply {
 | |
|             get {
 | |
|                 return _waitForReply;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         internal SqlStatistics () {
 | |
|         }
 | |
| 
 | |
|         internal void ContinueOnNewConnection() {
 | |
|             _startExecutionTimestamp = 0;
 | |
|             _startFetchTimestamp = 0;
 | |
|             _waitForDoneAfterRow = false;
 | |
|             _waitForReply = false;
 | |
|         }
 | |
| 
 | |
|         internal IDictionary GetHashtable() {
 | |
|             Hashtable ht = new Hashtable();
 | |
| 
 | |
|             ht.Add("BuffersReceived", _buffersReceived);
 | |
|             ht.Add("BuffersSent", _buffersSent);
 | |
|             ht.Add("BytesReceived", _bytesReceived);
 | |
|             ht.Add("BytesSent", _bytesSent);
 | |
|             ht.Add("CursorOpens", _cursorOpens);
 | |
|             ht.Add("IduCount", _iduCount);
 | |
|             ht.Add("IduRows", _iduRows);
 | |
|             ht.Add("PreparedExecs", _preparedExecs);
 | |
|             ht.Add("Prepares", _prepares);
 | |
|             ht.Add("SelectCount", _selectCount);
 | |
|             ht.Add("SelectRows", _selectRows);
 | |
|             ht.Add("ServerRoundtrips", _serverRoundtrips);
 | |
|             ht.Add("SumResultSets", _sumResultSets);
 | |
|             ht.Add("Transactions", _transactions);
 | |
|             ht.Add("UnpreparedExecs", _unpreparedExecs);
 | |
| 
 | |
|             ht.Add ("ConnectionTime", ADP.TimerToMilliseconds(_connectionTime));
 | |
|             ht.Add ("ExecutionTime", ADP.TimerToMilliseconds(_executionTime));
 | |
|             ht.Add ("NetworkServerTime", ADP.TimerToMilliseconds(_networkServerTime));
 | |
| 
 | |
|             return ht;
 | |
|         }
 | |
| 
 | |
|         internal bool RequestExecutionTimer () {
 | |
|             if (_startExecutionTimestamp == 0) {
 | |
|                 ADP.TimerCurrent(out _startExecutionTimestamp);
 | |
|                 return true;
 | |
|             }
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         internal void RequestNetworkServerTimer () {
 | |
|             Debug.Assert(_startExecutionTimestamp!=0, "No network time expected outside execution period");
 | |
|             if (_startNetworkServerTimestamp == 0) {
 | |
|                 ADP.TimerCurrent(out _startNetworkServerTimestamp);
 | |
|             }
 | |
|             _waitForReply = true;
 | |
|         }
 | |
| 
 | |
|         internal void ReleaseAndUpdateExecutionTimer () {
 | |
|             if (_startExecutionTimestamp > 0) {
 | |
|                 _executionTime += (ADP.TimerCurrent() - _startExecutionTimestamp);
 | |
|                 _startExecutionTimestamp = 0;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         internal void ReleaseAndUpdateNetworkServerTimer () {
 | |
|             if (_waitForReply && _startNetworkServerTimestamp > 0) {
 | |
|                 _networkServerTime += (ADP.TimerCurrent() - _startNetworkServerTimestamp);
 | |
|                 _startNetworkServerTimestamp = 0;
 | |
|             }
 | |
|             _waitForReply = false;
 | |
|         }
 | |
| 
 | |
|         internal void Reset() {
 | |
|             _buffersReceived = 0;
 | |
|             _buffersSent = 0;
 | |
|             _bytesReceived = 0;
 | |
|             _bytesSent = 0;
 | |
|             _connectionTime = 0;
 | |
|             _cursorOpens = 0;
 | |
|             _executionTime = 0;
 | |
|             _iduCount = 0;
 | |
|             _iduRows = 0;
 | |
|             _networkServerTime = 0;
 | |
|             _preparedExecs = 0;
 | |
|             _prepares = 0;
 | |
|             _selectCount = 0;
 | |
|             _selectRows = 0;
 | |
|             _serverRoundtrips = 0;
 | |
|             _sumResultSets = 0;
 | |
|             _transactions = 0;
 | |
|             _unpreparedExecs = 0;
 | |
|             _waitForDoneAfterRow = false;
 | |
|             _waitForReply = false;
 | |
|             _startExecutionTimestamp = 0;
 | |
|             _startNetworkServerTimestamp = 0;
 | |
|         }
 | |
| 
 | |
|         internal void SafeAdd (ref long value, long summand) {
 | |
|             if (long.MaxValue - value > summand) {
 | |
|                 value += summand;
 | |
|             }
 | |
|             else {
 | |
|                 value = long.MaxValue;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         internal long SafeIncrement(ref long value) {
 | |
|             if (value < long.MaxValue) value++;
 | |
|             return value;
 | |
|         }
 | |
| 
 | |
|         internal void UpdateStatistics() {
 | |
|             // update connection time
 | |
|             if (_closeTimestamp >= _openTimestamp) {
 | |
|                 SafeAdd(ref _connectionTime, _closeTimestamp - _openTimestamp);
 | |
|             }
 | |
|             else {
 | |
|                 _connectionTime = long.MaxValue;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 |