| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- namespace Abp.Collections.Extensions
- {
- /// <summary>
- /// Extension methods for <see cref="IEnumerable{T}"/>.
- /// </summary>
- public static class EnumerableExtensions
- {
- /// <summary>
- /// Concatenates the members of a constructed <see cref="IEnumerable{T}"/> collection of type System.String, using the specified separator between each member.
- /// This is a shortcut for string.Join(...)
- /// </summary>
- /// <param name="source">A collection that contains the strings to concatenate.</param>
- /// <param name="separator">The string to use as a separator. separator is included in the returned string only if values has more than one element.</param>
- /// <returns>A string that consists of the members of values delimited by the separator string. If values has no members, the method returns System.String.Empty.</returns>
- public static string JoinAsString(this IEnumerable<string> source, string separator)
- {
- return string.Join(separator, source);
- }
- /// <summary>
- /// Concatenates the members of a collection, using the specified separator between each member.
- /// This is a shortcut for string.Join(...)
- /// </summary>
- /// <param name="source">A collection that contains the objects to concatenate.</param>
- /// <param name="separator">The string to use as a separator. separator is included in the returned string only if values has more than one element.</param>
- /// <typeparam name="T">The type of the members of values.</typeparam>
- /// <returns>A string that consists of the members of values delimited by the separator string. If values has no members, the method returns System.String.Empty.</returns>
- public static string JoinAsString<T>(this IEnumerable<T> source, string separator)
- {
- return string.Join(separator, source);
- }
- /// <summary>
- /// Filters a <see cref="IEnumerable{T}"/> by given predicate if given condition is true.
- /// </summary>
- /// <param name="source">Enumerable to apply filtering</param>
- /// <param name="condition">A boolean value</param>
- /// <param name="predicate">Predicate to filter the enumerable</param>
- /// <returns>Filtered or not filtered enumerable based on <paramref name="condition"/></returns>
- public static IEnumerable<T> WhereIf<T>(this IEnumerable<T> source, bool condition, Func<T, bool> predicate)
- {
- return condition
- ? source.Where(predicate)
- : source;
- }
- /// <summary>
- /// Filters a <see cref="IEnumerable{T}"/> by given predicate if given condition is true.
- /// </summary>
- /// <param name="source">Enumerable to apply filtering</param>
- /// <param name="condition">A boolean value</param>
- /// <param name="predicate">Predicate to filter the enumerable</param>
- /// <returns>Filtered or not filtered enumerable based on <paramref name="condition"/></returns>
- public static IEnumerable<T> WhereIf<T>(this IEnumerable<T> source, bool condition, Func<T, int, bool> predicate)
- {
- return condition
- ? source.Where(predicate)
- : source;
- }
- }
- }
|