Skip to content

CppCXY/LanguageServer.Framework

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 

History

84 Commits
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

Language Server Framework

License: MIT NuGet CI Code Quality

A modern, high-performance .NET framework for building Language Server Protocol (LSP) servers with full LSP 3.18 specification support.

โœจ Features

  • ๐ŸŽฏ Full LSP 3.18 Support - Complete implementation of the latest LSP specification
  • โšก High Performance - Built with System.Text.Json source generation for optimal performance
  • ๐Ÿš€ AOT Ready - Full support for Ahead-of-Time (AOT) compilation
  • ๐Ÿ“ฆ Zero Dependencies - No dependency on Newtonsoft.Json or other third-party libraries
  • ๐ŸชŸ Window & Progress - Complete support for window messages, logging, and progress reporting
  • ๐Ÿ”ง Easy to Use - Simple, intuitive API for building language servers
  • ๐Ÿ“Š Performance Metrics - Built-in performance monitoring and telemetry support
  • ๐ŸŽจ Type Safe - Strongly typed protocol messages with full IntelliSense support

๐Ÿ“ฆ Installation

Install via NuGet Package Manager:

dotnet add package EmmyLua.LanguageServer.Framework

Or via Package Manager Console:

Install-Package EmmyLua.LanguageServer.Framework

๐Ÿš€ Quick Start

Basic Language Server

using EmmyLua.LanguageServer.Framework.Server;
using EmmyLua.LanguageServer.Framework.Protocol.Message.Initialize;

// Create a language server
var server = LanguageServer.From(Console.OpenStandardInput(), Console.OpenStandardOutput());

// Handle initialization
server.OnInitialize((request, serverInfo) =>
{
    serverInfo.Name = "My Language Server";
    serverInfo.Version = "1.0.0";
    return Task.CompletedTask;
});

// Handle initialized notification
server.OnInitialized(async (request) =>
{
    await server.Client.LogInfo("Server initialized!");
});

// Run the server
await server.Run();

Adding Handlers

using EmmyLua.LanguageServer.Framework.Server.Handler;

// Create a hover handler
public class MyHoverHandler : HoverHandlerBase
{
    protected override Task<Hover?> Handle(HoverParams request, CancellationToken token)
    {
        var hover = new Hover
        {
            Contents = new MarkupContent
            {
                Kind = MarkupKind.Markdown,
                Value = "**Hello from LSP!**"
            }
        };
        return Task.FromResult<Hover?>(hover);
    }

    public override void RegisterCapability(ServerCapabilities serverCapabilities,
        ClientCapabilities clientCapabilities)
    {
        serverCapabilities.HoverProvider = true;
    }
}

// Add handler to server
server.AddHandler(new MyHoverHandler());

๐Ÿ“š Documentation

Window Features

Display messages and collect user input:

// Show a message
await server.Client.ShowMessage(new ShowMessageParams
{
    Type = MessageType.Info,
    Message = "Operation completed successfully!"
});

// Request user action
var result = await server.Client.ShowMessageRequest(new ShowMessageRequestParams
{
    Type = MessageType.Warning,
    Message = "Do you want to continue?",
    Actions = new List<MessageActionItem>
    {
        new() { Title = "Yes" },
        new() { Title = "No" }
    }
}, cancellationToken);

// Log messages
await server.Client.LogError("An error occurred");
await server.Client.LogInfo("Processing file...");

Progress Reporting

Report progress for long-running operations:

// Using the helper class (recommended)
using var progress = await WorkDoneProgressReporter.Create(
    server.Client,
    title: "Analyzing workspace",
    cancellable: true
);

for (int i = 0; i < 100; i++)
{
    await progress.Report($"Processing file {i + 1}/100", (uint)i);
}

await progress.End("Analysis complete!");

For detailed examples, see LSP_WINDOW_PROGRESS_USAGE.md

Performance Monitoring

Enable performance metrics to monitor your server:

var options = new LanguageServerOptions
{
    EnablePerformanceTracing = true,
    PerformanceMetricsPrintInterval = TimeSpan.FromMinutes(5)
};

var server = LanguageServer.From(input, output, options);

// Get metrics at any time
var metrics = server.GetMetrics();
Console.WriteLine($"Total requests: {metrics.TotalRequestsHandled}");
Console.WriteLine($"Average duration: {metrics.AverageRequestDurationMs}ms");

๐ŸŽฏ Supported LSP Features

Text Document Synchronization

  • โœ…DidOpen / DidChange / DidClose / DidSave
  • โœ… WillSave / WillSaveWaitUntil

Language Features

  • โœ… Completion (with resolve support)
  • โœ… Hover
  • โœ… Signature Help
  • โœ… Definition / Declaration / Type Definition / Implementation
  • โœ… References
  • โœ… Document Highlight
  • โœ… Document Symbol
  • โœ… Code Action
  • โœ… Code Lens
  • โœ… Document Link
  • โœ… Document Color / Color Presentation
  • โœ… Document Formatting / Range Formatting / On Type Formatting
  • โœ… Rename / Prepare Rename
  • โœ… Folding Range
  • โœ… Selection Range
  • โœ… Call Hierarchy
  • โœ… Semantic Tokens
  • โœ… Inlay Hint
  • โœ… Inline Value
  • โœ… Type Hierarchy
  • โœ… Inline Completion
  • โœ… Linked Editing Range

Workspace Features

  • โœ… Workspace Symbols
  • โœ… Configuration
  • โœ… Workspace Folders
  • โœ… File Operations (Create/Rename/Delete)
  • โœ… File Watching
  • โœ… Diagnostics
  • โœ… Execute Command
  • โœ… Apply Edit

Window Features

  • โœ… ShowMessage / ShowMessageRequest
  • โœ… LogMessage
  • โœ… Work Done Progress
  • โœ… Telemetry

๐Ÿ—๏ธ Architecture

The framework is designed with extensibility and performance in mind:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚     Language Server Application         โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚           Handler Layer                 โ”‚
โ”‚  (HoverHandler, CompletionHandler...)   โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚         LanguageServer Core             โ”‚
โ”‚   (Protocol, Routing, Lifecycle)        โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚      JSON-RPC Protocol Layer            โ”‚
โ”‚  (JsonProtocolReader/Writer)            โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚         Transport Layer (stdio)         โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

๐Ÿ“– Examples

Check out the LanguageServer.Test project for a complete working example that demonstrates:

  • Server initialization
  • Multiple handlers implementation
  • Configuration management
  • Progress reporting
  • Error handling

๐ŸŒŸ Projects Using This Framework

๐Ÿค Contributing

Contributions are welcome! Please read our Contributing Guide for details on how to submit pull requests, report issues, and contribute to the project.

๐Ÿ“ License

This project is licensed under the MIT License - see the LICENSE file for details.

๐Ÿ”— Resources

๐Ÿ’ฌ Support


Made with โค๏ธ by the EmmyLua community

About

Supports the latest Language Server Protocol and AOT (Ahead-of-Time) compilation.

Topics

Resources

License

Contributing

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors

โšก