Comments (8)
Hi @Lumoryel , thank you for report, I'll be looking at this issue shortly
from aspect-injector.
Could you please provide some code samples where issue happens? Most probably the most weird method you applied an aspect to
from aspect-injector.
That was my [Aspected] Method:
public async Task SetPolarizerPosition(double aPolarizerValue)
{
await internSetPolarizerPosition(aPolarizerValue);
await updateAnalyzerPositionIfLinked();
}
Maybe it has something to do with async Methods or Task return values?
from aspect-injector.
That was my [Aspected] Method:
[LogCall]
public async Task SetPolarizerPosition(double aPolarizerValue)
{
await internSetPolarizerPosition(aPolarizerValue);
await updateAnalyzerPositionIfLinked();
}
Thats my aspect:
[Aspect(Scope.Global)]
[Injection(typeof(LogCall))]
public class LogCall : Attribute
{
[Advice(Kind.Before)]
[DebuggerStepThrough]
public void LogEnter(
[Argument(Source.Name)] string aName,
[Argument(Source.Type)] Type aType,
[Argument(Source.Arguments)] object[] aArgs,
[Argument(Source.Instance)] object aInstance
)
{
string aID = getLogIDString(aInstance);
string aArgsString = "";
if (aArgs.Any())
{
var aArgsStrings = aArgs.Select(createString).ToList();
aArgsString = string.Join(", ", aArgsStrings);
}
string aMessage = $"Invoke {aType.FullName}.{aName}{aID}({aArgsString})";
Console.WriteLine(aMessage);
}
[DebuggerStepThrough]
private static string createString(object x)
{
if (x == null)
{
return "<null>";
}
var aConverter = System.ComponentModel
.TypeDescriptor.GetConverter(x.GetType());
if (aConverter == null)
{
return x.ToString();
}
return aConverter.ConvertToInvariantString(x);
}
private static string getLogIDString(object aInstance)
{
string aID = "";
var aLogID = (aInstance as ILogID)?.GetLogID();
if (aLogID != null)
{
aID = "<" + aLogID.ToString() + ">";
}
return aID;
}
[DebuggerStepThrough]
[Advice(Kind.After)]
public void LogExit(
[Argument(Source.Name)] string aName,
[Argument(Source.Type)] Type aType,
[Argument(Source.ReturnType)] Type aReturnType,
[Argument(Source.ReturnValue)] object aReturn,
[Argument(Source.Instance)] object aInstance
)
{
string aID = "";// getLogIDString(aInstance);
string aReturnString = "";
if(aReturnType != typeof(void))
{
aReturnString = ": " + aReturn?.ToString() ?? "<null>";
}
string aMessage = $"Finished {aType.FullName}.{aName}{aID}()" + aReturnString;
Console.WriteLine(aMessage);
}
}
public interface ILogID
{
object GetLogID();
}
I'm using a .NET Framework 4.8 Project with C# 10.0 and #nullable enabled.
Maybe that helps?
from aspect-injector.
Just checking-in. Still working on this one
from aspect-injector.
Could you please try again with 2.8.1 ? I can't reproduce it with newer versions
from aspect-injector.
So far I can't reproduce the problem.
Best
Lumo
from aspect-injector.
Thank you @Lumoryel , feel free to reopen if needed
from aspect-injector.
Related Issues (20)
- Aspect Injector processing has failed (v2.8.0), Mono.Cecil.Cil.SymbolsNotFoundException HOT 9
- Multiple Same Validator Aspect On MethodFeature Can Not Wroking HOT 2
- System.NotSupportedException Mac M1 Mono HOT 3
- Feature: Provide debug symbols with NuGet package HOT 2
- Feature: Replace object[0] to Array.Empty<object> HOT 1
- Feature: Can cache Argument(Source.*) any input argument by static field? HOT 1
- Lack of M1 support when rosetta isn't installed HOT 14
- Unsupported language/version ? HOT 1
- Feature: Why `GetInstance` method for Factory should be static? HOT 3
- Local variables in sync methods are not visible in the VS debugger HOT 13
- Feature: Attribute Multicasting HOT 1
- [2.8.2][macOS] error AI_FAIL: Aspect Injector processing has failed HOT 27
- In a Advice method with Kind.Before and Target.Constructor, accessing mixed-in properties injected into a class containing an explicit constructor causes NullReferenceError. HOT 4
- Feature: Make `[assembly: Attribute]` work with virtual methods that don't have an override HOT 2
- Feature: Clean Cache
- error AI_ERR0: Processing failure: System.ObjectDisposedException: Cannot access a closed file.
- Failed to resolve assembly: 'mscorlib, Version=4.0.0.0
- AspectInjector|2.8.1 : error AI_ERR0: Processing failure: System.NotSupportedException: Arg_NotSupportedException
- Feature: Extend Universal attributes to support async aspects HOT 6
- System.InvalidOperationException: Aspect doesn't have global singleton injected
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from aspect-injector.