RSCG – rscg_queryables
RSCG – rscg_queryables
name | rscg_queryables |
nuget |
https://www.nuget.org/packages/rscg_queryables/ https://www.nuget.org/packages/rscg_queryablesCommon/ |
link | https://github.com/ignatandrei/rscg_queryables |
author | Andrei Ignat |
Generating code for .Where and .OrderBy by string, not by lambda
This is how you can use rscg_queryables .
The code that you start with is
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 | < Project Sdk = "Microsoft.NET.Sdk" > < PropertyGroup > < OutputType >Exe</ OutputType > < TargetFramework >net8.0</ TargetFramework > < ImplicitUsings >enable</ ImplicitUsings > < Nullable >enable</ Nullable > </ PropertyGroup > < ItemGroup > < PackageReference Include = "rscg_queryablesCommon" Version = "2024.1110.1815" /> < PackageReference Include = "rscg_queryables" Version = "2024.1110.1815" OutputItemType = "Analyzer" ReferenceOutputAssembly = "false" /> </ ItemGroup > < PropertyGroup > < EmitCompilerGeneratedFiles >true</ EmitCompilerGeneratedFiles > < CompilerGeneratedFilesOutputPath >$(BaseIntermediateOutputPath)\GX</ CompilerGeneratedFilesOutputPath > </ PropertyGroup > </ Project > |
The code that you will use is
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | using SortAndWhere; Console.WriteLine( "Hello, World!" ); var students = new Student[] { new Student { FirstName = "John" , LastName = "Doe" , StartYear = 1935}, new Student { FirstName = "Ignat" , LastName = "Andrei" , StartYear = 1989 }, }; var orderedExplicitly = students.OrderBy(p => p.FirstName).ToArray(); var orderedImplicitly = students.OrderBy( "firStnaMe" ).ToArray(); var orderedImplicitly2 = students.AsQueryable().OrderBy( "fIrsTnAme" ).ToArray(); //Search by property name var search = students.AsQueryable().Where( "firstName" , rscg_queryablesCommon.WhereOperator.Equal, "John" ).ToArray(); Console.WriteLine( "found : " + search.Length); search = students.AsQueryable().Where(Student_.Where_Expr( "firstName" , rscg_queryablesCommon.WhereOperator.Equal, "John" )).ToArray(); Console.WriteLine( "found : " + search.Length); |
01 02 03 04 05 06 07 08 09 10 11 12 13 | using rscg_queryablesCommon; namespace SortAndWhere; [MakeSortable] [MakeWhere] public class Student { public string FirstName { get ; set ; } = string .Empty; public string LastName { get ; set ; } = string .Empty; public int StartYear { get ; set ; } } |
The code that is generated is
001 002 003 004 005 006 007 008 009 010 011 012 013 014 015 016 017 018 019 020 021 022 023 024 025 026 027 028 029 030 031 032 033 034 035 036 037 038 039 040 041 042 043 044 045 046 047 048 049 050 051 052 053 054 055 056 057 058 059 060 061 062 063 064 065 066 067 068 069 070 071 072 073 074 075 076 077 078 079 080 081 082 083 084 085 086 087 088 089 090 091 092 093 094 095 096 097 098 099 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 | public static partial class ExtensionsSortable_SortAndWhere_Student { #region Enumerable public static System.Linq.IOrderedEnumerable<global::SortAndWhere.Student> OrderBy ( this IEnumerable<global::SortAndWhere.Student> source, string propertyName ) { return OrderByAscDesc(source,propertyName, true ); } public static System.Linq.IOrderedEnumerable<global::SortAndWhere.Student> OrderByDescending ( this IEnumerable<global::SortAndWhere.Student> source, string propertyName ) { return OrderByAscDesc(source,propertyName, false ); } public static System.Linq.IOrderedEnumerable<global::SortAndWhere.Student> OrderByAscDesc ( this IEnumerable<global::SortAndWhere.Student> source, string propertyName, bool Ascending ) { if ( string .Equals(propertyName, "FirstName" , StringComparison.OrdinalIgnoreCase)){ if (Ascending) return source.OrderBy(x => x.FirstName); else return source.OrderByDescending(x => x.FirstName); } if ( string .Equals(propertyName, "LastName" , StringComparison.OrdinalIgnoreCase)){ if (Ascending) return source.OrderBy(x => x.LastName); else return source.OrderByDescending(x => x.LastName); } if ( string .Equals(propertyName, "StartYear" , StringComparison.OrdinalIgnoreCase)){ if (Ascending) return source.OrderBy(x => x.StartYear); else return source.OrderByDescending(x => x.StartYear); } throw new ArgumentException($ "Property {propertyName} not found" , propertyName); } public static System.Linq.IOrderedEnumerable<global::SortAndWhere.Student> ThenByAscDesc ( this IOrderedEnumerable<global::SortAndWhere.Student> source, string propertyName, bool Ascending ) { if ( string .Equals(propertyName, "FirstName" , StringComparison.OrdinalIgnoreCase)){ if (Ascending) return source.ThenBy(x => x.FirstName); else return source.ThenByDescending(x => x.FirstName); } if ( string .Equals(propertyName, "LastName" , StringComparison.OrdinalIgnoreCase)){ if (Ascending) return source.ThenBy(x => x.LastName); else return source.ThenByDescending(x => x.LastName); } if ( string .Equals(propertyName, "StartYear" , StringComparison.OrdinalIgnoreCase)){ if (Ascending) return source.ThenBy(x => x.StartYear); else return source.ThenByDescending(x => x.StartYear); } throw new ArgumentException($ "Property {propertyName} not found" , propertyName); } public static System.Linq.IOrderedEnumerable<global::SortAndWhere.Student> ThenBy ( this IOrderedEnumerable<global::SortAndWhere.Student> source, string propertyName ) { return ThenByAscDesc(source,propertyName, true ); } public static System.Linq.IOrderedEnumerable<global::SortAndWhere.Student> ThenByDescending ( this IOrderedEnumerable<global::SortAndWhere.Student> source, string propertyName ) { return ThenByAscDesc(source,propertyName, false ); } #endregion #region Queryable public static System.Linq.IOrderedQueryable<global::SortAndWhere.Student> OrderBy ( this IQueryable<global::SortAndWhere.Student> source, string propertyName ) { return OrderByAscDesc(source,propertyName, true ); } public static System.Linq.IOrderedQueryable<global::SortAndWhere.Student> OrderByDescending ( this IQueryable<global::SortAndWhere.Student> source, string propertyName ) { return OrderByAscDesc(source,propertyName, false ); } public static System.Linq.IOrderedQueryable<global::SortAndWhere.Student> OrderByAscDesc ( this IQueryable<global::SortAndWhere.Student> source, string propertyName, bool Ascending ) { if ( string .Equals(propertyName, "FirstName" , StringComparison.OrdinalIgnoreCase)){ if (Ascending) return source.OrderBy(x => x.FirstName); else return source.OrderByDescending(x => x.FirstName); } if ( string .Equals(propertyName, "LastName" , StringComparison.OrdinalIgnoreCase)){ if (Ascending) return source.OrderBy(x => x.LastName); else return source.OrderByDescending(x => x.LastName); } if ( string .Equals(propertyName, "StartYear" , StringComparison.OrdinalIgnoreCase)){ if (Ascending) return source.OrderBy(x => x.StartYear); else return source.OrderByDescending(x => x.StartYear); } throw new ArgumentException($ "Property {propertyName} not found" , propertyName); } public static System.Linq.IOrderedQueryable<global::SortAndWhere.Student> ThenByAscDesc ( this IOrderedQueryable<global::SortAndWhere.Student> source, string propertyName, bool Ascending ) { if ( string .Equals(propertyName, "FirstName" , StringComparison.OrdinalIgnoreCase)){ if (Ascending) return source.ThenBy(x => x.FirstName); else return source.ThenByDescending(x => x.FirstName); } if ( string .Equals(propertyName, "LastName" , StringComparison.OrdinalIgnoreCase)){ if (Ascending) return source.ThenBy(x => x.LastName); else return source.ThenByDescending(x => x.LastName); } if ( string .Equals(propertyName, "StartYear" , StringComparison.OrdinalIgnoreCase)){ if (Ascending) return source.ThenBy(x => x.StartYear); else return source.ThenByDescending(x => x.StartYear); } throw new ArgumentException($ "Property {propertyName} not found" , propertyName); } public static System.Linq.IOrderedQueryable<global::SortAndWhere.Student> ThenBy ( this IOrderedQueryable<global::SortAndWhere.Student> source, string propertyName ) { return ThenByAscDesc(source,propertyName, true ); } public static System.Linq.IOrderedQueryable<global::SortAndWhere.Student> ThenByDescending ( this IOrderedQueryable<global::SortAndWhere.Student> source, string propertyName ) { return ThenByAscDesc(source,propertyName, false ); } #endregion } |
001 002 003 004 005 006 007 008 009 010 011 012 013 014 015 016 017 018 019 020 021 022 023 024 025 026 027 028 029 030 031 032 033 034 035 036 037 038 039 040 041 042 043 044 045 046 047 048 049 050 051 052 053 054 055 056 057 058 059 060 061 062 063 064 065 066 067 068 069 070 071 072 073 074 075 076 077 078 079 080 081 082 083 084 085 086 087 088 089 090 091 092 093 094 095 096 097 098 099 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 | public static class ExtensionsWhere_SortAndWhere_Student{ internal static System.Linq.Expressions.Expression < Func < global::SortAndWhere.Student, bool >> FirstName_Expr_Equal( string argument) => (a => a.FirstName== argument); internal static Func<global::SortAndWhere.Student, bool > FirstName_Equal( string argument) => (a => a.FirstName== argument); internal static System.Linq.Expressions.Expression < Func < global::SortAndWhere.Student, bool >> FirstName_Expr_NotEqual( string argument) => (a => a.FirstName != argument); internal static Func<global::SortAndWhere.Student, bool > FirstName_NotEqual( string argument) => (a => a.FirstName != argument); internal static System.Linq.Expressions.Expression < Func < global::SortAndWhere.Student, bool >> LastName_Expr_Equal( string argument) => (a => a.LastName== argument); internal static Func<global::SortAndWhere.Student, bool > LastName_Equal( string argument) => (a => a.LastName== argument); internal static System.Linq.Expressions.Expression < Func < global::SortAndWhere.Student, bool >> LastName_Expr_NotEqual( string argument) => (a => a.LastName != argument); internal static Func<global::SortAndWhere.Student, bool > LastName_NotEqual( string argument) => (a => a.LastName != argument); internal static System.Linq.Expressions.Expression < Func < global::SortAndWhere.Student, bool >> StartYear_Expr_Equal( int argument) => (a => a.StartYear== argument); internal static Func<global::SortAndWhere.Student, bool > StartYear_Equal( int argument) => (a => a.StartYear== argument); internal static System.Linq.Expressions.Expression < Func < global::SortAndWhere.Student, bool >> StartYear_Expr_NotEqual( int argument) => (a => a.StartYear != argument); internal static Func<global::SortAndWhere.Student, bool > StartYear_NotEqual( int argument) => (a => a.StartYear != argument); } public static class Student_{ public static System.Linq.IQueryable<global::SortAndWhere.Student> Where( this System.Linq.IQueryable<global::SortAndWhere.Student> original, string propertyName,rscg_queryablesCommon.WhereOperator operatorWhere, string argument) { return original.Where(Where_Expr(propertyName, operatorWhere, argument)); } public static System.Linq.Expressions.Expression < Func < global::SortAndWhere.Student, bool >> Where_Expr( string propertyName,rscg_queryablesCommon.WhereOperator operatorWhere, string argument) { if ( string .Equals(propertyName, "FirstName" , StringComparison.OrdinalIgnoreCase)){ switch (operatorWhere){ case rscg_queryablesCommon.WhereOperator.Equal: return ExtensionsWhere_SortAndWhere_Student.FirstName_Expr_Equal( argument); case rscg_queryablesCommon.WhereOperator.NotEqual: return ExtensionsWhere_SortAndWhere_Student.FirstName_Expr_NotEqual( argument); default : throw new ArgumentException($ "Operator {operatorWhere} not found" ); } //end switch } //end if FirstName if ( string .Equals(propertyName, "LastName" , StringComparison.OrdinalIgnoreCase)){ switch (operatorWhere){ case rscg_queryablesCommon.WhereOperator.Equal: return ExtensionsWhere_SortAndWhere_Student.LastName_Expr_Equal( argument); case rscg_queryablesCommon.WhereOperator.NotEqual: return ExtensionsWhere_SortAndWhere_Student.LastName_Expr_NotEqual( argument); default : throw new ArgumentException($ "Operator {operatorWhere} not found" ); } //end switch } //end if LastName throw new ArgumentException( "Property " + propertyName + " not found for string type" ); } public static Func<global::SortAndWhere.Student, bool > Where( string propertyName,rscg_queryablesCommon.WhereOperator operatorWhere, string argument) { if ( string .Equals(propertyName, "FirstName" , StringComparison.OrdinalIgnoreCase)){ switch (operatorWhere){ case rscg_queryablesCommon.WhereOperator.Equal: return ExtensionsWhere_SortAndWhere_Student.FirstName_Equal( argument); case rscg_queryablesCommon.WhereOperator.NotEqual: return ExtensionsWhere_SortAndWhere_Student.FirstName_NotEqual( argument); default : throw new ArgumentException($ "Operator {operatorWhere} not found" ); } //end switch } //end if FirstName if ( string .Equals(propertyName, "LastName" , StringComparison.OrdinalIgnoreCase)){ switch (operatorWhere){ case rscg_queryablesCommon.WhereOperator.Equal: return ExtensionsWhere_SortAndWhere_Student.LastName_Equal( argument); case rscg_queryablesCommon.WhereOperator.NotEqual: return ExtensionsWhere_SortAndWhere_Student.LastName_NotEqual( argument); default : throw new ArgumentException($ "Operator {operatorWhere} not found" ); } //end switch } //end if LastName throw new ArgumentException( "Property " + propertyName + " not found for string type" ); } public static System.Linq.IQueryable<global::SortAndWhere.Student> Where( this System.Linq.IQueryable<global::SortAndWhere.Student> original, string propertyName,rscg_queryablesCommon.WhereOperator operatorWhere, int argument) { return original.Where(Where_Expr(propertyName, operatorWhere, argument)); } public static System.Linq.Expressions.Expression < Func < global::SortAndWhere.Student, bool >> Where_Expr( string propertyName,rscg_queryablesCommon.WhereOperator operatorWhere, int argument) { if ( string .Equals(propertyName, "StartYear" , StringComparison.OrdinalIgnoreCase)){ switch (operatorWhere){ case rscg_queryablesCommon.WhereOperator.Equal: return ExtensionsWhere_SortAndWhere_Student.StartYear_Expr_Equal( argument); case rscg_queryablesCommon.WhereOperator.NotEqual: return ExtensionsWhere_SortAndWhere_Student.StartYear_Expr_NotEqual( argument); default : throw new ArgumentException($ "Operator {operatorWhere} not found" ); } //end switch } //end if StartYear throw new ArgumentException( "Property " + propertyName + " not found for int type" ); } public static Func<global::SortAndWhere.Student, bool > Where( string propertyName,rscg_queryablesCommon.WhereOperator operatorWhere, int argument) { if ( string .Equals(propertyName, "StartYear" , StringComparison.OrdinalIgnoreCase)){ switch (operatorWhere){ case rscg_queryablesCommon.WhereOperator.Equal: return ExtensionsWhere_SortAndWhere_Student.StartYear_Equal( argument); case rscg_queryablesCommon.WhereOperator.NotEqual: return ExtensionsWhere_SortAndWhere_Student.StartYear_NotEqual( argument); default : throw new ArgumentException($ "Operator {operatorWhere} not found" ); } //end switch } //end if StartYear throw new ArgumentException( "Property " + propertyName + " not found for int type" ); } } |
Code and pdf at
https://ignatandrei.github.io/RSCG_Examples/v2/docs/rscg_queryables
Leave a Reply