aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.Horizon.Kernel.Generators/Kernel/SyscallSyntaxReceiver.cs
diff options
context:
space:
mode:
Diffstat (limited to 'Ryujinx.Horizon.Kernel.Generators/Kernel/SyscallSyntaxReceiver.cs')
-rw-r--r--Ryujinx.Horizon.Kernel.Generators/Kernel/SyscallSyntaxReceiver.cs54
1 files changed, 54 insertions, 0 deletions
diff --git a/Ryujinx.Horizon.Kernel.Generators/Kernel/SyscallSyntaxReceiver.cs b/Ryujinx.Horizon.Kernel.Generators/Kernel/SyscallSyntaxReceiver.cs
new file mode 100644
index 00000000..e2e8e1d3
--- /dev/null
+++ b/Ryujinx.Horizon.Kernel.Generators/Kernel/SyscallSyntaxReceiver.cs
@@ -0,0 +1,54 @@
+using Microsoft.CodeAnalysis;
+using Microsoft.CodeAnalysis.CSharp.Syntax;
+using System.Collections.Generic;
+using System.Linq;
+
+namespace Ryujinx.Horizon.Generators.Kernel
+{
+ class SyscallSyntaxReceiver : ISyntaxReceiver
+ {
+ public List<MethodDeclarationSyntax> SvcImplementations { get; }
+
+ public SyscallSyntaxReceiver()
+ {
+ SvcImplementations = new List<MethodDeclarationSyntax>();
+ }
+
+ public void OnVisitSyntaxNode(SyntaxNode syntaxNode)
+ {
+ if (syntaxNode is ClassDeclarationSyntax classDeclaration && classDeclaration.AttributeLists.Count != 0)
+ {
+ foreach (var attributeList in classDeclaration.AttributeLists)
+ {
+ if (attributeList.Attributes.Any(x => x.Name.GetText().ToString() == "SvcImpl"))
+ {
+ foreach (var memberDeclaration in classDeclaration.Members)
+ {
+ if (memberDeclaration is MethodDeclarationSyntax methodDeclaration)
+ {
+ VisitMethod(methodDeclaration);
+ }
+ }
+
+ break;
+ }
+ }
+ }
+ }
+
+ private void VisitMethod(MethodDeclarationSyntax methodDeclaration)
+ {
+ if (methodDeclaration.AttributeLists.Count != 0)
+ {
+ foreach (var attributeList in methodDeclaration.AttributeLists)
+ {
+ if (attributeList.Attributes.Any(x => x.Name.GetText().ToString() == "Svc"))
+ {
+ SvcImplementations.Add(methodDeclaration);
+ break;
+ }
+ }
+ }
+ }
+ }
+}