Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/piotrstenke/Durian

Durian is a collection of Roslyn-based analyzers and source generators that extend the default capabilities of C#.
https://github.com/piotrstenke/Durian

analysis csharp roslyn roslyn-analyzer source-generation

Last synced: 2 months ago
JSON representation

Durian is a collection of Roslyn-based analyzers and source generators that extend the default capabilities of C#.

Awesome Lists containing this project

README

        





Version


Downloads



Build


License


Durian logo

##

**Durian is a collection of Roslyn-based analyzers, source generators and utility libraries that bring many extensions to C#, with heavy emphasis on features that can be found in other existing languages. It's main goal is to make C# easier and more pleasant to use through reducing necessary boilerplate code, while at the same time providing additional layers of flexibility.**

## Table of Contents

1. [Current State](#current-state)
2. [Features](#features)
1. [DefaultParam](#defaultparam)
2. [InterfaceTargets](#interfacetargets)
3. [FriendClass](#friendclass)
3. [In Progress](#in-progress)
1. [CopyFrom](#copyfrom)
4. [Experimental](#experimental)
1. [ConstExpr](#constexpr)

## Current State

Durian is at an early stage of its evolution - many core features are still missing, being either in early development or planning phase. As for now, three fully-fledged modules are ready - *DefaultParam*, *InterfaceTargets* and *FriendClass*.

## Features

To see more about a specific feature, click on its name.

### [DefaultParam](src/Durian.DefaultParam/README.md)
*DefaultParam* allows to specify a default type for a generic parameter.

```csharp
using Durian;

public class Test<[DefaultParam(typeof(string))]T>
{
public T Value { get; }

public Test(T value)
{
Value = value;
}
}

public class Program
{
static void Main()
{
// Test can be used without type parameters - 'T' defaults to 'string'.
Test test1 = new Test("");

// Type parameter can be stated explicitly.
Test test2 = new Test("");
}
}

```

### [InterfaceTargets](src/Durian.InterfaceTargets/README.md)

*InterfaceTargets*, similar to how [System.AttributeUsageAttribute](https://docs.microsoft.com/en-us/dotnet/api/system.attributeusageattribute) works, allows to specify what kinds of members an interface can be implemented by.

```csharp
using Durian;

[InterfaceTargets(InterfaceTargets.Class)]
public interface ITest
{
}

// Success!
// ITest can be implemented, because ClassTest is a class.
public class ClassTest : ITest
{
}

// Error!
// ITest cannot be implemented, because StructTest is a struct, and ITest is valid only for classes.
public struct StructTest : ITest
{
}

```

### [FriendClass](src/Durian.FriendClass/README.md)

*FriendClass* allows to limit access to 'internal' members by specifying a fixed list of friend types.

```csharp
using Durian;

[FriendClass(typeof(A))]
public class Test
{
internal static string Key { get; }
}

public class A
{
public string GetKey()
{
// Success!
// Type 'A' is a friend of 'Test', so it can safely access internal members.
return Test.Key;
}
}

public class B
{
public string GetKey()
{
// Error!
// Type 'B' is not a friend of 'Test', so it cannot access internal members.
return Test.Key;
}
}
```

### [CopyFrom](src/Durian.CopyFrom/README.md)

*CopyFrom* allows to copy implementations of members to other members, without the need for inheritance. A regex pattern can be provided to customize the copied implementation.

```csharp
using Durian;

[CopyFromType(typeof(Other)), Pattern("text", "name")]
public partial class Test
{
}

public class Other
{
private string _text;

void Set(string text)
{
_text = text;
}
}

// Generated

partial class Test
{
private string _name;

void Set(string name)
{
_name = name;
}
}

```

## In Progress

The following modules are still in active development and are yet to be released in a not-yet-specified future.

## Experimental

Experimental stage is a playground of sorts - modules included here are very early in development and there in no guarantee that they will be ever actually released.

### [ConstExpr](src/Durian.ConstExpr/README.md)

*ConstExpr* allows a method to be executed at compile-time, producing actual constants.

```csharp
using Durian;

public static class Utility
{
[ConstExpr]
public static int Sum(params int[] values)
{
int sum = 0;

for(int i = 0; i < values.Length; i++)
{
sum += values[i];
}

return sum;
}
}

[ConstExprSource("Utility.Sum", 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, Name = "Sum_10")]
public static partial class Constants
{
}

// Generated

public static partial class Constants
{
public const int Sum_10 = 55;
}

```

##

*\(Written by Piotr Stenke\)*