mirror of
https://github.com/xcp-ng/xenadmin.git
synced 2025-01-11 04:32:32 +01:00
165 lines
5.9 KiB
C#
165 lines
5.9 KiB
C#
|
/* 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 XenAdmin.Core;
|
|||
|
|
|||
|
namespace XenAdmin.Controls
|
|||
|
{
|
|||
|
/// <summary>
|
|||
|
/// This class is an implementation of the 'IComparer' interface. Sorts using StringUtility.NaturalCompare.
|
|||
|
/// See http://support.microsoft.com/kb/319401.
|
|||
|
/// </summary>
|
|||
|
public class ListViewColumnSorter : IComparer
|
|||
|
{
|
|||
|
/// <summary>
|
|||
|
/// Specifies the column to be sorted
|
|||
|
/// </summary>
|
|||
|
private int ColumnToSort;
|
|||
|
/// <summary>
|
|||
|
/// Specifies the order in which to sort (i.e. 'Ascending').
|
|||
|
/// </summary>
|
|||
|
private SortOrder OrderOfSort;
|
|||
|
|
|||
|
private Comparison<ListViewItem.ListViewSubItem> comparer;
|
|||
|
/// <summary>
|
|||
|
/// The Comparison that is used. If set to null, StringUtility.NaturalCompare will be used. The default value is null.
|
|||
|
/// </summary>
|
|||
|
public Comparison<ListViewItem.ListViewSubItem> Comparer
|
|||
|
{
|
|||
|
get
|
|||
|
{
|
|||
|
return comparer;
|
|||
|
}
|
|||
|
set
|
|||
|
{
|
|||
|
comparer = value;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// Class constructor. Initializes various elements
|
|||
|
/// </summary>
|
|||
|
public ListViewColumnSorter()
|
|||
|
{
|
|||
|
// Initialize the column to '0'
|
|||
|
ColumnToSort = 0;
|
|||
|
|
|||
|
// Initialize the sort order to 'none'
|
|||
|
OrderOfSort = SortOrder.None;
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// This method is inherited from the IComparer interface.
|
|||
|
/// </summary>
|
|||
|
/// <param name="x">First object to be compared</param>
|
|||
|
/// <param name="y">Second object to be compared</param>
|
|||
|
/// <returns>The result of the comparison. "0" if equal, negative if 'x' is less than 'y' and positive if 'x' is greater than 'y'</returns>
|
|||
|
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;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// Gets or sets the number of the column to which to apply the sorting operation (Defaults to '0').
|
|||
|
/// </summary>
|
|||
|
public int SortColumn
|
|||
|
{
|
|||
|
set
|
|||
|
{
|
|||
|
ColumnToSort = value;
|
|||
|
}
|
|||
|
get
|
|||
|
{
|
|||
|
return ColumnToSort;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// Gets or sets the order of sorting to apply (for example, 'Ascending' or 'Descending').
|
|||
|
/// </summary>
|
|||
|
public SortOrder Order
|
|||
|
{
|
|||
|
set
|
|||
|
{
|
|||
|
OrderOfSort = value;
|
|||
|
}
|
|||
|
get
|
|||
|
{
|
|||
|
return OrderOfSort;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
}
|