From 5033c29b5abc540e0e4805f75eea7d2f87c118d0 Mon Sep 17 00:00:00 2001 From: Andrei Horodniceanu Date: Wed, 21 Aug 2024 11:55:48 +0300 Subject: [PATCH] Keep the default option for dependencies when serializing a sdl recipe Signed-off-by: Andrei Horodniceanu --- source/dub/recipe/sdl.d | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/source/dub/recipe/sdl.d b/source/dub/recipe/sdl.d index e6872c2a2..9e1c89bb7 100644 --- a/source/dub/recipe/sdl.d +++ b/source/dub/recipe/sdl.d @@ -286,6 +286,7 @@ private Tag[] toSDL(const scope ref BuildSettingsTemplate bs) }, ); if (d.optional) attribs ~= new Attribute(null, "optional", Value(true)); + if (d.default_) attribs ~= new Attribute(null, "default", Value(true)); auto t = new Tag(null, "dependency", [Value(pack)], attribs); if (d.settings !is typeof(d.settings).init) t.add(d.settings.toSDL()); @@ -697,6 +698,20 @@ lflags "-b" "-c" `); } +unittest { // test that default is preserved after serialization + immutable sdl = `name "optional-deps" +dependency "foo-bar" version="1.1.2" optional=true default=true`; + PackageRecipe rec; + parseSDLTest(rec, sdl); + with (rec.buildSettings) { + assert(dependencies["foo-bar"].optional); + assert(dependencies["foo-bar"].default_); + } + immutable back = toSDL(rec).toSDLDocument(); + import std.algorithm : canFind; + assert(back.canFind("default=true")); +} + unittest { auto sdl = "name \"test\"\nsourcePaths"; PackageRecipe rec;