dart-sdk/pkg/dds
Alexander Aprelev 17781dbc36 [frontend/dds] Enable frontend server and dds to pass through types, method and class information for expression evaluation.
This information is needed for correct expression compilation.
Method name, for example, introduced in 48d8225b17 is needed for the compiler to confirm extension method context.

For flutter https://github.com/flutter/flutter/pull/128084 will be needed.

Fixes https://github.com/dart-lang/sdk/issues/52522

Change-Id: I32e53a953ebfb51afb462f4e2169fac0bcee0a7a
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/306908
Reviewed-by: Jens Johansen <jensj@google.com>
Reviewed-by: Ben Konyi <bkonyi@google.com>
Commit-Queue: Alexander Aprelev <aam@google.com>
2023-06-02 16:27:28 +00:00
..
bin
example
lib [frontend/dds] Enable frontend server and dds to pass through types, method and class information for expression evaluation. 2023-06-02 16:27:28 +00:00
test Export dap package from DDS for flutter tools 2023-05-23 19:23:35 +00:00
tool Export dap package from DDS for flutter tools 2023-05-23 19:23:35 +00:00
.gitignore
analysis_options.yaml [pkg/dds] use package:lints/recommended.yaml 2023-02-21 18:30:23 +00:00
CHANGELOG.md [frontend/dds] Enable frontend server and dds to pass through types, method and class information for expression evaluation. 2023-06-02 16:27:28 +00:00
dds_protocol.md [DDS] Add getPerfettoVMTimelineWithCpuSamples RPC 2023-05-04 20:23:09 +00:00
LICENSE
OWNERS
pubspec.yaml [frontend/dds] Enable frontend server and dds to pass through types, method and class information for expression evaluation. 2023-06-02 16:27:28 +00:00
README.md

pub package package publisher

A package used to spawn the Dart Developer Service (DDS), which is used to communicate with a Dart VM Service instance and provide extended functionality to the core VM Service Protocol.

Functionality

Existing VM Service clients can issue both HTTP, websocket, and SSE requests to a running DDS instance as if it were an instance of the VM Service itself. If a request corresponds to an RPC defined in the VM Service Protocol, DDS will forward the request and return the response from the VM Service. Requests corresponding to an RPC defined in the DDS Protocol will be handled directly by the DDS instance.

SSE Support

For certain web clients it may be preferable or required to communicate with DDS using server-sent events (SSE). DDS has an SSE handler listening for requests on /$debugHandler.

SSE and package:vm_service example

import 'package:sse/sse.dart';
import 'package:vm_service/vm_service.dart';

void main() {
  // Establish connection with DDS using SSE.
  final ddsChannel = SseClient('${ddsUri}\$debugHandler');

  // Wait for ddsChannel to be established
  await ddsChannel.onOpen.first;

  // Initialize VmService using the sink and stream from ddsChannel.
  final vmService = VmService(
    ddsChannel.stream,
    (e) => ddsChannel.sink.add(e),
  );

  // You're ready to query DDS and the VM service!
  print(await vmService.getVersion());
}