Re: [netconf] [core] YANG encoding in CBOR

Andy Bierman <andy@yumaworks.com> Wed, 27 March 2019 20:11 UTC

Return-Path: <andy@yumaworks.com>
X-Original-To: netconf@ietfa.amsl.com
Delivered-To: netconf@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id DB25E120407 for <netconf@ietfa.amsl.com>; Wed, 27 Mar 2019 13:11:53 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.9
X-Spam-Level:
X-Spam-Status: No, score=-1.9 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIMWL_WL_MED=-0.001, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_NONE=-0.0001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=unavailable autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (2048-bit key) header.d=yumaworks-com.20150623.gappssmtp.com
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id frLvQkGvrcId for <netconf@ietfa.amsl.com>; Wed, 27 Mar 2019 13:11:47 -0700 (PDT)
Received: from mail-lj1-x22d.google.com (mail-lj1-x22d.google.com [IPv6:2a00:1450:4864:20::22d]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 9DFB212037C for <netconf@ietf.org>; Wed, 27 Mar 2019 13:11:46 -0700 (PDT)
Received: by mail-lj1-x22d.google.com with SMTP id v22so15560075lje.9 for <netconf@ietf.org>; Wed, 27 Mar 2019 13:11:46 -0700 (PDT)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=yumaworks-com.20150623.gappssmtp.com; s=20150623; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=90TeAK73HHjK9UBzuuhwpkeMXOKnEbcWq+6rGTaEsbQ=; b=QgweE4TrTuQUMPDcqQyVe+3a77my0gT+C9OQsQGwGA7WRHOc72RAd9+oEZAMUkXseO 6misLk3o3CBtvBc03PPneK4DA34WsAulKcZYZEEKgOovr+W9hob2VMU4gyM/oIuc6B65 mbyK64mDK2p4DV++lakKIWdW2RYOO9Z/FTNi9XTPwIbDhsC0AKdJP0P2fEfvbiznqORb dqALb/Q+qsq+4mYT1P1LHY4GCQ37H8YPperJAgSOdMO3OpiPEsFq5KFkPnUaQw+SYIvk 8kHsBJiJeFbCe88XCDwiNrFqZPcNzo6Wesx5nv8K5sbQFfFWvG461dPABFjN2Ir8btS8 ZgTw==
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=90TeAK73HHjK9UBzuuhwpkeMXOKnEbcWq+6rGTaEsbQ=; b=Szshjr0IFeyQA8jR8G8dBlsEkQOiUym3mDEDM32emkemIBzLPOpsSiF8yIko7/y8Dd RySZOupG3PG/YfIid/wEAsOsYa1Cti2I9bxcHCcEa/NFB/vpVV48yM0Kq7UZn+8jDevK sZpmyzlU0YFbiLdkLtOq9OcDtJHkTPSpn2EU7uJjjhQoI0mnc9wvDOxoRVCE3xWDA+VV Tv/zhG0NEe4msuxHGHr4wp+5c4CqrR6w1QKlT/ZQQlF060d/kJq8bKtp6RuzpxOc1m0C c8h0QonoMJv7uL0M/natju/F6Wt10TGXqz0grHJqvYxFmPTDxmgr6LmHuIWbBy1/HJ8a iHLg==
X-Gm-Message-State: APjAAAUI/hv0fr0P/5K+jtXKxSygbpDTTzLmaxjD7vrYc/EbH59AN00w l4j+jByxFDw7Fidbqrnpe2rfWQ7P0HyPY6w51ALcpQ==
X-Google-Smtp-Source: APXvYqw5ulRlB4x7JVZxYDqkw8S0X3B+fZhXRQYDFzXfu8hzVne+gBKUiW4CozzCyvfBuS/DcMH3SDkhL453hhvLbto=
X-Received: by 2002:a2e:844a:: with SMTP id u10mr9295158ljh.41.1553717504655; Wed, 27 Mar 2019 13:11:44 -0700 (PDT)
MIME-Version: 1.0
References: <6235c6683ff14848a661f8b8cec94280@XCH-RCD-007.cisco.com> <BL0PR06MB5042823429DB7CDA0F33408B9A430@BL0PR06MB5042.namprd06.prod.outlook.com> <588401AB-483E-40F5-95BB-20A066E56DAC@tzi.org> <15fbaf84b20343a1b83f40b571149a14@XCH-RCD-007.cisco.com> <1ADF8201-ABB4-44FD-A515-F3F8E0DBF5FC@tzi.org> <20190323101003.gp3zvsvqqwc26jip@anna.jacobs.jacobs-university.de> <871s2vqsxi.fsf@nic.cz> <BL0PR06MB5042C9AA6B4A0CCD913F50D89A580@BL0PR06MB5042.namprd06.prod.outlook.com> <20190327061637.g5a7t7nulk7kyh2v@anna.jacobs.jacobs-university.de> <1f8b326e0e05b400457b9446d52a7b0f6c90e05b.camel@nic.cz> <CABCOCHRKhvUzrDcELOWGHY5HWt7EQpq-iYdY84z3oqOCQjsATg@mail.gmail.com> <ce1bfc2916dcc3eadf03a46f901e08060c3858b2.camel@nic.cz>
In-Reply-To: <ce1bfc2916dcc3eadf03a46f901e08060c3858b2.camel@nic.cz>
From: Andy Bierman <andy@yumaworks.com>
Date: Wed, 27 Mar 2019 13:11:33 -0700
Message-ID: <CABCOCHSm5LuqjSqvgxfXHKDai=76kKK=4mG=B+Dy9DEjaZpz0w@mail.gmail.com>
To: Ladislav Lhotka <lhotka@nic.cz>
Cc: Juergen Schoenwaelder <j.schoenwaelder@jacobs-university.de>, Michel Veillette <Michel.Veillette@trilliant.com>, "netconf@ietf.org" <netconf@ietf.org>, "core@ietf.org" <core@ietf.org>
Content-Type: multipart/alternative; boundary="000000000000f2603d0585190b7c"
Archived-At: <https://mailarchive.ietf.org/arch/msg/netconf/qe9rEAWr-97GGN0btWYZ0YT22aw>
Subject: Re: [netconf] [core] YANG encoding in CBOR
X-BeenThere: netconf@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: NETCONF WG list <netconf.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/netconf>, <mailto:netconf-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/netconf/>
List-Post: <mailto:netconf@ietf.org>
List-Help: <mailto:netconf-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/netconf>, <mailto:netconf-request@ietf.org?subject=subscribe>
X-List-Received-Date: Wed, 27 Mar 2019 20:11:58 -0000

On Wed, Mar 27, 2019 at 12:54 PM Ladislav Lhotka <lhotka@nic.cz> wrote:

> Andy Bierman píše v St 27. 03. 2019 v 09:13 -0700:
> >
> >
> > On Wed, Mar 27, 2019 at 1:40 AM Ladislav Lhotka <lhotka@nic.cz> wrote:
> > > On Wed, 2019-03-27 at 07:16 +0100, Juergen Schoenwaelder wrote:
> > > > Hi,
> > > >
> > > > a union can be formed by using member types that are imported and not
> > > > under change control of a single author/organization and ideally this
> > > > should work without complex coordination of name and number spaces.
> > > > Duplicate enum/bits values are legal in YANG today so an encoding has
> > > > to deal with this aspect of life.
> > > >
> > > > A robust fix to all these problems will be to tag the type members in
> > > > order to discriminate the values in the encodings. This, however,
> will
> > > > take some time to specify and we will need to preserve backwards
> > > > compatibility with unions without a tag (but compilers can encourage
> > > > people to add tags whenever modules are updated).
> > >
> > > I already opened a new issue for this in yang-next:
> > >
> > > https://github.com/netmod-wg/yang-next/issues/72
> > >
> >
> > We already explored the solution of giving the member types numbers
> > so they could be used in CBOR but this was rejected because it is so
> complex
> > to implement.
>
> I don't think it is too complex. Get the type in the schema, get the
> member,
> that's all. It is much easier and more robust than the current algorithm.
>
>
no it isn't easier because the algorithm is error-prone.
Renumbering un-named types nested within unions and referenced named types
over many revisions of the module is not easy.
The encoding MUST NOT change EVER -- even if the union type is expanded.


> >
> > Consider when union is within union, and the types are named types from
>
> Union within union is no problem: it jut requires a sequence of numbers.
>
>
do not agree since the union can have a member type added



> > other modules. Union types can be legally updated in new versions of the
> > module,
>
> Again, I don't agree. Sec. 11 in RFC 7950 says:
>
>    o  A "type" statement may be replaced with another "type" statement
>       that does not change the syntax or semantics of the type.
>       ...
>
>

   type uint32 { range "1..8"; }

I can refactor that into 2 types (1..4 and 5..8)
This does not change the semantics of the union type but it adds a member
type
Other refactoring is possible that will also change the number of member
types.

Also, deviations do not follow this rule



> Adding a new member clearly changes the semantics of the type, if not
> syntax.
>
>
no it doesn't always change the semantics



> > but the position assignments for SID can never change.
>
> The annotation would also help resolve the differences between JSON and
> XML. SID
> is only available in CBOR.
>
> >
> > Even without this complexity this solution would cause the
> encoder/decoder to
> > be very schema-aware.
>
> The current method of resolving unions is totally schema-aware (somewhat
> less so
> in JSON).
>
>
No -- it just needs to know string vs. number.
Not schema aware at all.


> Lada
>
>
Andy


> >
> >
> > BTW, creating SIDs for enums and bits will break if the server uses
> 'deviate
> > replace type'.
> > There is no way to number the deviated type since this is
> server-specific not
> > part of the original module
> > and the deviation is not actually a data-def-stmt.
> >
> >
> > > Lada
> > >
> >
> > Andy
> >
> > > >
> > > > /js
> > > >
> > > > On Wed, Mar 27, 2019 at 01:12:52AM +0000, Michel Veillette wrote:
> > > > > Hi Ladislav
> > > > >
> > > > > If I summarize this issue of multiple enumerations or bits in a
> union,
> > > this
> > > > > problem can be solve by the following approaches:
> > > > >
> > > > > - To not allows these duplicate values or positions to happen in
> YANG
> > > > > - To encode enumerations and bits as string (in all unions or only
> when
> > > > > multiple enumerations or bits are defined)
> > > > > - To encode enumerations and bits as SID (in all unions or only
> when
> > > > > multiple enumerations or bits are defined)
> > > > > - To encode enumerations and bits as delta between the value SID
> and the
> > > > > leaf SID (in all unions or only when multiple enumerations or bits
> are
> > > > > defined)
> > > > >
> > > > > In this email, I will like to focus on the first option, fixing the
> > > problem
> > > > > directly in YANG instead of fixing the consequences.
> > > > >
> > > > > Without any changes in YANG, a union with multiple enumeration or
> bits
> > > can
> > > > > be constructed without value or position overlaps.
> > > > > For example:
> > > > >
> > > > >   leaf multiple-enumerations-test-1 {
> > > > >     type union {
> > > > >       type enumeration {
> > > > >         enum "Monday" { value 0; }
> > > > >         enum "Tuesday" { value 1; }
> > > > >         enum "Wednesday" { value 2; }
> > > > >         enum "Thursday" { value 3; }
> > > > >         enum "Friday" { value 4; }
> > > > >
> > > > >       }
> > > > >       type enumeration {
> > > > >         enum "Saturday" { value 5; }
> > > > >         enum "Sunday" { value 6; }
> > > > >       }
> > > > >     }
> > > > >   }
> > > > >
> > > > >   leaf multiple-bits-test-1 {
> > > > >     type union {
> > > > >       type bits {
> > > > >         bit  "Monday" { position  0; }
> > > > >         bit "Tuesday" { position  1; }
> > > > >         bit "Wednesday" { position  2; }
> > > > >         bit "Thursday" { position  3; }
> > > > >         bit "Friday" { position  4; }
> > > > >
> > > > >       }
> > > > >       type bits {
> > > > >         bit "Saturday" { position 5; }
> > > > >         bit "Sunday" { position 6; }
> > > > >       }
> > > > >     }
> > > > >   }
> > > > >
> > > > > When using already defined typedef, avoiding overlap is less
> obvious
> > > without
> > > > > some help.
> > > > > To help building unions with already defined typedefs, I propose to
> > > > > introduce two extensions.
> > > > >
> > > > >   extension value-offset {
> > > > >     argument offset {
> > > > >       yin-element true;
> > > > >     }
> > > > >     description
> > > > >       "Offset added to each enum value of the associated
> enumeration.";
> > > > >   }
> > > > >
> > > > >   extension position-offset {
> > > > >     argument offset {
> > > > >       yin-element true;
> > > > >     }
> > > > >     description
> > > > >       "Offset value added to each bit position of the associated
> bits.";
> > > > >   }
> > > > >
> > > > > The value-offset extension can be used as follow:
> > > > >
> > > > >     type enumeration {
> > > > >       enum "Monday";
> > > > >       enum "Tuesday";
> > > > >       enum "Wednesday";
> > > > >       enum "Thursday";
> > > > >       enum "Friday";
> > > > >     }
> > > > >   }
> > > > >
> > > > >   typedef weekend {
> > > > >     type enumeration {
> > > > >       enum "Saturday";
> > > > >       enum "Sunday";
> > > > >     }
> > > > >   }
> > > > >
> > > > >   leaf multiple-enumerations-test-3 {
> > > > >     type union {
> > > > >       type weekdays;
> > > > >       type weekend {
> > > > >         ext:value-offset 5;
> > > > >       }
> > > > >     }
> > > > >   }
> > > > >
> > > > > The position-offset extension can be used as follow:
> > > > >
> > > > >   typedef weekdays-flags {
> > > > >     type bits {
> > > > >       bit "Monday";
> > > > >       bit "Tuesday";
> > > > >       bit "Wednesday";
> > > > >       bit "Thursday";
> > > > >       bit "Friday";
> > > > >     }
> > > > >   }
> > > > >
> > > > >   typedef weekend-flags {
> > > > >     type bits {
> > > > >       bit "Saturday";
> > > > >       bit "Sunday";
> > > > >     }
> > > > >   }
> > > > >
> > > > >   leaf multiple-bits-test-3 {
> > > > >     type union {
> > > > >       type weekdays-flags;
> > > > >       type weekend-flags {
> > > > >         ext:position-offset 5;
> > > > >       }
> > > > >     }
> > > > >   }
> > > > >
> > > > > The yang file in attachment show different examples based on this
> > > approach.
> > > > > This module have been validated using
> > > http://www.yangvalidator.com/validator
> > > > >
> > > > > If this approach is accepted, tools like pyang should be updated to
> > > produce
> > > > > an error if multiple enumerations or bits are defined with value or
> > > position
> > > > > overleaps.
> > > > >
> > > > > Please comment,
> > > > > Michel
> > > > >
> > > > > -----Original Message-----
> > > > > From: Ladislav Lhotka <lhotka@nic.cz>
> > > > > Sent: Monday, March 25, 2019 4:07 AM
> > > > > To: Juergen Schoenwaelder <j.schoenwaelder@jacobs-university.de>;
> > > Carsten
> > > > > Bormann <cabo@tzi.org>
> > > > > Cc: Michel Veillette <Michel.Veillette@trilliant.com>;
> netconf@ietf.org;
> > >
> > > > > core@ietf.org
> > > > > Subject: Re: [netconf] YANG encoding in CBOR
> > > > >
> > > > > Juergen Schoenwaelder <j.schoenwaelder@jacobs-university.de>
> writes:
> > > > >
> > > > > > I think we need to look at the whole picture and in which
> direction
> > > we
> > > > > > want to go. In the longer term, I would prefer a solution where
> the
> > > > > > values of a union are discriminated. The current XML encoding
> > > > > > behaviour of 'first match wins' is fragile (for example, if
> someone
> > > > > > adds an enum to a type, the interpretation of data can change).
> > > > > >
> > > > > > Look at this:
> > > > > >
> > > > > > typedef bar {
> > > > > >   type union {
> > > > > >     type enumeration { enum "1"; value 2; enum "2"; value 1; }
> > > > > >     type uint8;
> > > > > >   }
> > > > > > }
> > > > > >
> > > > > > We have some encodings that send the string representations of
> the
> > > > > > values and some encodings that prefer to send numeric
> representations
> > > > > > where possible. In order to have a robust solution, encodings
> should
> > > > > > likely indicate to which type the value belongs.
> > > > >
> > > > > Perhaps the easiest way would be to use (optional) annotation that
> > > > > specifies, using an ordinal number, which of the member types is
> used
> > > for
> > > > > the particular instance. But since there can be unions inside
> unions, a
> > > list
> > > > > of numbers would be needed in general.
> > > > >
> > > > > Lada
> > > > >
> > > > > > /js
> > > > > >
> > > > > > On Sat, Mar 23, 2019 at 10:03:32AM +0100, Carsten Bormann wrote:
> > > > > > > Well, if that is a problem, we can go for a longer
> representation
> > > within
> > > > > > > unions (section 6.12).  Theoretically, we could do that only of
> > > there is
> > > > > > > more than one enum in the union type (so things stay efficient
> if
> > > there
> > > > > > > is only one), but that might pose difficulties with model
> evolution.
> > > > > > >
> > > > > > > Going for a string representation repeats the feature of XML
> YANG
> > > (which
> > > > > > > was ported over to JSON YANG):
> > > > > > >
> > > > > > > typedef foo {
> > > > > > >   type union {
> > > > > > >     type enumeration {
> > > > > > >       enum red { value 1; }
> > > > > > >       enum breen { value 2; }
> > > > > > >       enum glue { value 3; }
> > > > > > >     }
> > > > > > >     type enumeration {
> > > > > > >       enum tacks { value 1; }
> > > > > > >       enum nails { value 2; }
> > > > > > >       enum glue { value 3; }
> > > > > > >     }
> > > > > > >   }
> > > > > > > }
> > > > > > >
> > > > > > > If you use “glue”, you don’t know which of the enumerations are
> > > being
> > > > > > > used.
> > > > > > >
> > > > > > > Using SIDs, we can do better.
> > > > > > >
> > > > > > > So what do we have to do to get the SID tool to allocate SIDs
> for
> > > enum
> > > > > > > values?
> > > > > > >
> > > > > > > We could then define the CBOR tag for enums in unions to take
> the
> > > usual
> > > > > > > SID difference (delta relative to the environment, I’d think),
> not
> > > an
> > > > > > > integer value.
> > > > > > >
> > > > > > > Several of us are at the hackathon and could make something
> happen
> > > today
> > > > > > > and tomorrow.
> > > > > > >
> > > > > > > Grüße, Carsten
> > > > > > >
> > > > > > >
> > > > > > > > On Mar 22, 2019, at 18:30, Rob Wilton (rwilton) <
> rwilton@cisco.com
> > > >
> > > > > > > > wrote:
> > > > > > > >
> > > > > > > > I guess that the concern is that this introduces more
> variation in
> > > how
> > > > > > > > data is interpreted between the different XML/JSON/CBOR
> encodings.
> > > > > > > >
> > > > > > > > E.g. if someone switched from XML to CBOR, suddenly the
> > > configuration
> > > > > > > > or state data may have a different meaning.
> > > > > > > >
> > > > > > > > Thanks,
> > > > > > > > Rob
> > > > > > > >
> > > > > > > >
> > > > > > > > > -----Original Message-----
> > > > > > > > > From: Carsten Bormann <cabo@tzi.org>
> > > > > > > > > Sent: 22 March 2019 16:08
> > > > > > > > > To: Michel Veillette <Michel.Veillette@trilliant.com>
> > > > > > > > > Cc: Rob Wilton (rwilton) <rwilton@cisco.com>;
> core@ietf.org;
> > > > > > > > > netconf@ietf.org
> > > > > > > > > Subject: Re: [netconf] YANG encoding in CBOR
> > > > > > > > >
> > > > > > > > > On Mar 22, 2019, at 16:45, Michel Veillette
> > > > > > > > > <Michel.Veillette@trilliant.com>
> > > > > > > > > wrote:
> > > > > > > > > > The only potential problem I aware is when multiple
> > > enumerations
> > > > > > > > > > are part of
> > > > > > > > > the same union.
> > > > > > > > > > Value 4 from enumeration A will be encoded the same way
> as
> > > Value
> > > > > > > > > > 4 from
> > > > > > > > > enumeration B.
> > > > > > > > >
> > > > > > > > > … and that is not a problem for the XML version, because
> the
> > > > > > > > > string is being used instead of the value.  (But then if
> two
> > > > > > > > > enumerations share a string, you have the equivalent
> problem in
> > > > > > > > > the XML serialization.)
> > > > > > > > >
> > > > > > > > > Anyway, I haven’t seen a piece of real-world YANG that
> actually
> > > > > > > > > has this problem, so I would be a bit reluctant to make
> CBOR-
> > > based
> > > > > > > > > implementations more complex (and less efficient) so solve
> this
> > > > > > > > > (non-?)problem.
> > > > > > > > >
> > > > > > > > > Grüße, Carsten
> > > > > > > >
> > > > > > > >
> > > > > > >
> > > > > > > _______________________________________________
> > > > > > > netconf mailing list
> > > > > > > netconf@ietf.org
> > > > > > >
> > > https://can01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww
> > > > > > >
> > > .ietf.org%2Fmailman%2Flistinfo%2Fnetconf&amp;data=02%7C01%7C%7C343ea8
> > > > > > >
> > > d1cf8f4e39afc708d6b0f8d874%7C4f6fbd130dfb415085c3d43260c04309%7C0%7C1
> > > > > > >
> > > %7C636890980182553400&amp;sdata=u1KFAYAus16B8a7sgsBfPfIquOptMlaOb%2B0
> > > > > > > kvPZgr4o%3D&amp;reserved=0
> > > > > >
> > > > > > --
> > > > > > Juergen Schoenwaelder           Jacobs University Bremen gGmbH
> > > > > > Phone: +49 421 200 3587         Campus Ring 1 | 28759 Bremen |
> Germany
> > > > > > Fax:   +49 421 200 3103         <
> > > > > >
> > >
> https://can01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.jacobs-university.de%2F&amp;data=02%7C01%7C%7C343ea8d1cf8f4e39afc708d6b0f8d874%7C4f6fbd130dfb415085c3d43260c04309%7C0%7C1%7C636890980182553400&amp;sdata=TrW2iL3nUDlZ%2BVvhPxWeqdU1X%2BqvFCnXyodX6Bu1e94%3D&amp;reserved=0
> > > > > > >
> > > > > >
> > > > > >
> > > > > > On Sat, Mar 23, 2019 at 10:03:32AM +0100, Carsten Bormann wrote:
> > > > > > > Well, if that is a problem, we can go for a longer
> representation
> > > within
> > > > > > > unions (section 6.12).  Theoretically, we could do that only of
> > > there is
> > > > > > > more than one enum in the union type (so things stay efficient
> if
> > > there
> > > > > > > is only one), but that might pose difficulties with model
> evolution.
> > > > > > >
> > > > > > > Going for a string representation repeats the feature of XML
> YANG
> > > (which
> > > > > > > was ported over to JSON YANG):
> > > > > > >
> > > > > > > typedef foo {
> > > > > > >   type union {
> > > > > > >     type enumeration {
> > > > > > >       enum red { value 1; }
> > > > > > >       enum breen { value 2; }
> > > > > > >       enum glue { value 3; }
> > > > > > >     }
> > > > > > >     type enumeration {
> > > > > > >       enum tacks { value 1; }
> > > > > > >       enum nails { value 2; }
> > > > > > >       enum glue { value 3; }
> > > > > > >     }
> > > > > > >   }
> > > > > > > }
> > > > > > >
> > > > > > > If you use “glue”, you don’t know which of the enumerations are
> > > being
> > > > > > > used.
> > > > > > >
> > > > > > > Using SIDs, we can do better.
> > > > > > >
> > > > > > > So what do we have to do to get the SID tool to allocate SIDs
> for
> > > enum
> > > > > > > values?
> > > > > > >
> > > > > > > We could then define the CBOR tag for enums in unions to take
> the
> > > usual
> > > > > > > SID difference (delta relative to the environment, I’d think),
> not
> > > an
> > > > > > > integer value.
> > > > > > >
> > > > > > > Several of us are at the hackathon and could make something
> happen
> > > today
> > > > > > > and tomorrow.
> > > > > > >
> > > > > > > Grüße, Carsten
> > > > > > >
> > > > > > >
> > > > > > > > On Mar 22, 2019, at 18:30, Rob Wilton (rwilton) <
> rwilton@cisco.com
> > > >
> > > > > > > > wrote:
> > > > > > > >
> > > > > > > > I guess that the concern is that this introduces more
> variation in
> > > how
> > > > > > > > data is interpreted between the different XML/JSON/CBOR
> encodings.
> > > > > > > >
> > > > > > > > E.g. if someone switched from XML to CBOR, suddenly the
> > > configuration
> > > > > > > > or state data may have a different meaning.
> > > > > > > >
> > > > > > > > Thanks,
> > > > > > > > Rob
> > > > > > > >
> > > > > > > >
> > > > > > > > > -----Original Message-----
> > > > > > > > > From: Carsten Bormann <cabo@tzi.org>
> > > > > > > > > Sent: 22 March 2019 16:08
> > > > > > > > > To: Michel Veillette <Michel.Veillette@trilliant.com>
> > > > > > > > > Cc: Rob Wilton (rwilton) <rwilton@cisco.com>;
> core@ietf.org;
> > > > > > > > > netconf@ietf.org
> > > > > > > > > Subject: Re: [netconf] YANG encoding in CBOR
> > > > > > > > >
> > > > > > > > > On Mar 22, 2019, at 16:45, Michel Veillette
> > > > > > > > > <Michel.Veillette@trilliant.com>
> > > > > > > > > wrote:
> > > > > > > > > > The only potential problem I aware is when multiple
> > > enumerations
> > > > > > > > > > are part of
> > > > > > > > > the same union.
> > > > > > > > > > Value 4 from enumeration A will be encoded the same way
> as
> > > Value
> > > > > > > > > > 4 from
> > > > > > > > > enumeration B.
> > > > > > > > >
> > > > > > > > > … and that is not a problem for the XML version, because
> the
> > > > > > > > > string is being used instead of the value.  (But then if
> two
> > > > > > > > > enumerations share a string, you have the equivalent
> problem in
> > > > > > > > > the XML serialization.)
> > > > > > > > >
> > > > > > > > > Anyway, I haven’t seen a piece of real-world YANG that
> actually
> > > > > > > > > has this problem, so I would be a bit reluctant to make
> CBOR-
> > > based
> > > > > > > > > implementations more complex (and less efficient) so solve
> this
> > > > > > > > > (non-?)problem.
> > > > > > > > >
> > > > > > > > > Grüße, Carsten
> > > > > > > >
> > > > > > > >
> > > > > > >
> > > > > > > _______________________________________________
> > > > > > > netconf mailing list
> > > > > > > netconf@ietf.org
> > > > > > >
> > > https://can01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww
> > > > > > >
> > > .ietf.org%2Fmailman%2Flistinfo%2Fnetconf&amp;data=02%7C01%7C%7C343ea8
> > > > > > >
> > > d1cf8f4e39afc708d6b0f8d874%7C4f6fbd130dfb415085c3d43260c04309%7C0%7C1
> > > > > > >
> > > %7C636890980182553400&amp;sdata=u1KFAYAus16B8a7sgsBfPfIquOptMlaOb%2B0
> > > > > > > kvPZgr4o%3D&amp;reserved=0
> > > > > >
> > > > > > --
> > > > > > Juergen Schoenwaelder           Jacobs University Bremen gGmbH
> > > > > > Phone: +49 421 200 3587         Campus Ring 1 | 28759 Bremen |
> Germany
> > > > > > Fax:   +49 421 200 3103         <
> > > > > >
> > >
> https://can01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.jacobs-university.de%2F&amp;data=02%7C01%7C%7C343ea8d1cf8f4e39afc708d6b0f8d874%7C4f6fbd130dfb415085c3d43260c04309%7C0%7C1%7C636890980182553400&amp;sdata=TrW2iL3nUDlZ%2BVvhPxWeqdU1X%2BqvFCnXyodX6Bu1e94%3D&amp;reserved=0
> > > > > > >
> > > > > >
> > > > > > _______________________________________________
> > > > > > netconf mailing list
> > > > > > netconf@ietf.org
> > > > > >
> https://can01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.
> > > > > > ietf.org
> %2Fmailman%2Flistinfo%2Fnetconf&amp;data=02%7C01%7C%7C343ea8d1
> > > > > >
> cf8f4e39afc708d6b0f8d874%7C4f6fbd130dfb415085c3d43260c04309%7C0%7C1%7C
> > > > > >
> 636890980182553400&amp;sdata=u1KFAYAus16B8a7sgsBfPfIquOptMlaOb%2B0kvPZ
> > > > > > gr4o%3D&amp;reserved=0
> > > > >
> > > > > --
> > > > > Ladislav Lhotka
> > > > > Head, CZ.NIC Labs
> > > > > PGP Key ID: 0xB8F92B08A9F76C67
> > > >
> > > >
> --
> Ladislav Lhotka
> Head, CZ.NIC Labs
> PGP Key ID: 0xB8F92B08A9F76C67
>
>