/* Copyright (c) Citrix Systems, Inc.
* All rights reserved.
*
* Redistribution and use in source and binary forms,
* with or without modification, are permitted provided
* that the following conditions are met:
*
* * Redistributions of source code must retain the above
* copyright notice, this list of conditions and the
* following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the
* following disclaimer in the documentation and/or other
* materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
* CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
using System;
using System.Collections;
using System.Windows.Forms;
using XenCenterLib;
namespace XenAdmin.Controls
{
///
/// This class is an implementation of the 'IComparer' interface. Sorts using StringUtility.NaturalCompare.
/// See http://support.microsoft.com/kb/319401.
///
public class ListViewColumnSorter : IComparer
{
///
/// Specifies the column to be sorted
///
private int ColumnToSort;
///
/// Specifies the order in which to sort (i.e. 'Ascending').
///
private SortOrder OrderOfSort;
private Comparison comparer;
///
/// The Comparison that is used. If set to null, StringUtility.NaturalCompare will be used. The default value is null.
///
public Comparison Comparer
{
get
{
return comparer;
}
set
{
comparer = value;
}
}
///
/// Class constructor. Initializes various elements
///
public ListViewColumnSorter()
{
// Initialize the column to '0'
ColumnToSort = 0;
// Initialize the sort order to 'none'
OrderOfSort = SortOrder.None;
}
///
/// This method is inherited from the IComparer interface.
///
/// First object to be compared
/// Second object to be compared
/// The result of the comparison. "0" if equal, negative if 'x' is less than 'y' and positive if 'x' is greater than 'y'
public int Compare(object x, object y)
{
int compareResult;
ListViewItem listviewX, listviewY;
// Cast the objects to be compared to ListViewItem objects
listviewX = (ListViewItem)x;
listviewY = (ListViewItem)y;
if (listviewX.SubItems.Count == 0 || listviewY.SubItems.Count == 0)
return 0;
else if (comparer == null)
{
if (listviewX.SubItems.Count > ColumnToSort && listviewY.SubItems.Count > ColumnToSort)
compareResult = StringUtility.NaturalCompare(listviewX.SubItems[ColumnToSort].Text, listviewY.SubItems[ColumnToSort].Text);
else
compareResult = StringUtility.NaturalCompare(listviewX.SubItems[0].Text, listviewY.SubItems[0].Text);
}
else
{
if (listviewX.SubItems.Count > ColumnToSort && listviewY.SubItems.Count > ColumnToSort)
compareResult = comparer(listviewX.SubItems[ColumnToSort], listviewY.SubItems[ColumnToSort]);
else
compareResult = comparer(listviewX.SubItems[0], listviewY.SubItems[0]);
}
// Calculate correct return value based on object comparison
if (OrderOfSort == SortOrder.Ascending)
{
// Ascending sort is selected, return normal result of compare operation
return compareResult;
}
else if (OrderOfSort == SortOrder.Descending)
{
// Descending sort is selected, return negative result of compare operation
return (-compareResult);
}
else
{
// Return '0' to indicate they are equal
return 0;
}
}
///
/// Gets or sets the number of the column to which to apply the sorting operation (Defaults to '0').
///
public int SortColumn
{
set
{
ColumnToSort = value;
}
get
{
return ColumnToSort;
}
}
///
/// Gets or sets the order of sorting to apply (for example, 'Ascending' or 'Descending').
///
public SortOrder Order
{
set
{
OrderOfSort = value;
}
get
{
return OrderOfSort;
}
}
}
}