aboutsummaryrefslogtreecommitdiff
path: root/src/Ryujinx.Horizon.Kernel.Generators/Kernel/SyscallSyntaxReceiver.cs
diff options
context:
space:
mode:
Diffstat (limited to 'src/Ryujinx.Horizon.Kernel.Generators/Kernel/SyscallSyntaxReceiver.cs')
-rw-r--r--src/Ryujinx.Horizon.Kernel.Generators/Kernel/SyscallSyntaxReceiver.cs53
1 files changed, 53 insertions, 0 deletions
diff --git a/src/Ryujinx.Horizon.Kernel.Generators/Kernel/SyscallSyntaxReceiver.cs b/src/Ryujinx.Horizon.Kernel.Generators/Kernel/SyscallSyntaxReceiver.cs
new file mode 100644
index 00000000..e480a859
--- /dev/null
+++ b/src/Ryujinx.Horizon.Kernel.Generators/Kernel/SyscallSyntaxReceiver.cs
@@ -0,0 +1,53 @@
+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)
+ {
+ return;
+ }
+
+ if (!classDeclaration.AttributeLists.Any(attributeList =>
+ attributeList.Attributes.Any(x => x.Name.GetText().ToString() == "SvcImpl")))
+ {
+ return;
+ }
+
+ foreach (var memberDeclaration in classDeclaration.Members)
+ {
+ if (memberDeclaration is MethodDeclarationSyntax methodDeclaration)
+ {
+ VisitMethod(methodDeclaration);
+ }
+ }
+ }
+
+ private void VisitMethod(MethodDeclarationSyntax methodDeclaration)
+ {
+ if (methodDeclaration.AttributeLists.Count == 0)
+ {
+ return;
+ }
+
+ if (methodDeclaration.AttributeLists.Any(attributeList =>
+ attributeList.Attributes.Any(x => x.Name.GetText().ToString() == "Svc")))
+ {
+ SvcImplementations.Add(methodDeclaration);
+ }
+ }
+ }
+}