Readonly schema schema :  {       attributes :  {           color :  {               type :  "optional" ;               value :  {                   pattern :  RegExp ;                   type :  "regex" ;                   zero :  "#000000" ;               } ;           } ;           default-x :  {               label :  "default-x" ;               type :  "label" ;               value :  {                   type :  "optional" ;                   value :  {                       max :  number ;                       min :  number ;                       type :  "float" ;                   } ;               } ;           } ;           default-y :  {               label :  "default-y" ;               type :  "label" ;               value :  {                   type :  "optional" ;                   value :  {                       max :  number ;                       min :  number ;                       type :  "float" ;                   } ;               } ;           } ;           font-family :  {               type :  "optional" ;               value :  {                   pattern :  RegExp ;                   type :  "regex" ;                   zero :  " " ;               } ;           } ;           font-size :  {               type :  "optional" ;               value :  {                   choices :  readonly  [ {                       choices :  readonly  [ "xx-small" ,  "x-small" ,  "small" ,  "medium" ,  "large" ,  "x-large" ,  "xx-large" ] ;                       type :  "choices" ;                   } ,  {                       max :  number ;                       min :  number ;                       type :  "float" ;                   } ] ;                   type :  "choices" ;               } ;           } ;           font-style :  {               type :  "optional" ;               value :  {                   choices :  readonly  [ "normal" ,  "italic" ] ;                   type :  "choices" ;               } ;           } ;           font-weight :  {               type :  "optional" ;               value :  {                   choices :  readonly  [ "normal" ,  "bold" ] ;                   type :  "choices" ;               } ;           } ;           relative-x :  {               label :  "relative-x" ;               type :  "label" ;               value :  {                   type :  "optional" ;                   value :  {                       max :  number ;                       min :  number ;                       type :  "float" ;                   } ;               } ;           } ;           relative-y :  {               label :  "relative-y" ;               type :  "label" ;               value :  {                   type :  "optional" ;                   value :  {                       max :  number ;                       min :  number ;                       type :  "float" ;                   } ;               } ;           } ;           text :  {               type :  "optional" ;               value :  {                   type :  "string" ;               } ;           } ;       } ;       contents :  readonly  [ {           type :  "required" ;           value :  {               label :  "degree-type-value" ;               type :  "label" ;               value :  {                   choices :  readonly  [ "add" ,  "alter" ,  "subtract" ] ;                   type :  "choices" ;               } ;           } ;       } ] ;       name :  "degree-type" ;  }  = DegreeType.schema 
Type declaration Readonly attributes :  {       color :  {           type :  "optional" ;           value :  {               pattern :  RegExp ;               type :  "regex" ;               zero :  "#000000" ;           } ;       } ;       default-x :  {           label :  "default-x" ;           type :  "label" ;           value :  {               type :  "optional" ;               value :  {                   max :  number ;                   min :  number ;                   type :  "float" ;               } ;           } ;       } ;       default-y :  {           label :  "default-y" ;           type :  "label" ;           value :  {               type :  "optional" ;               value :  {                   max :  number ;                   min :  number ;                   type :  "float" ;               } ;           } ;       } ;       font-family :  {           type :  "optional" ;           value :  {               pattern :  RegExp ;               type :  "regex" ;               zero :  " " ;           } ;       } ;       font-size :  {           type :  "optional" ;           value :  {               choices :  readonly  [ {                   choices :  readonly  [ "xx-small" ,  "x-small" ,  "small" ,  "medium" ,  "large" ,  "x-large" ,  "xx-large" ] ;                   type :  "choices" ;               } ,  {                   max :  number ;                   min :  number ;                   type :  "float" ;               } ] ;               type :  "choices" ;           } ;       } ;       font-style :  {           type :  "optional" ;           value :  {               choices :  readonly  [ "normal" ,  "italic" ] ;               type :  "choices" ;           } ;       } ;       font-weight :  {           type :  "optional" ;           value :  {               choices :  readonly  [ "normal" ,  "bold" ] ;               type :  "choices" ;           } ;       } ;       relative-x :  {           label :  "relative-x" ;           type :  "label" ;           value :  {               type :  "optional" ;               value :  {                   max :  number ;                   min :  number ;                   type :  "float" ;               } ;           } ;       } ;       relative-y :  {           label :  "relative-y" ;           type :  "label" ;           value :  {               type :  "optional" ;               value :  {                   max :  number ;                   min :  number ;                   type :  "float" ;               } ;           } ;       } ;       text :  {           type :  "optional" ;           value :  {               type :  "string" ;           } ;       } ;  } Readonly color :  {       type :  "optional" ;       value :  {           pattern :  RegExp ;           type :  "regex" ;           zero :  "#000000" ;       } ;  } Readonly type :  "optional" Readonly value :  {       pattern :  RegExp ;       type :  "regex" ;       zero :  "#000000" ;  } Readonly pattern :  RegExp Readonly type :  "regex" Readonly zero :  "#000000" Readonly default- :  {       label :  "default-x" ;       type :  "label" ;       value :  {           type :  "optional" ;           value :  {               max :  number ;               min :  number ;               type :  "float" ;           } ;       } ;  } Readonly label :  "default-x" Readonly type :  "label" Readonly value :  {       type :  "optional" ;       value :  {           max :  number ;           min :  number ;           type :  "float" ;       } ;  } Readonly type :  "optional" Readonly value :  {       max :  number ;       min :  number ;       type :  "float" ;  } Readonly max :  number Readonly min :  number Readonly type :  "float" Readonly default- :  {       label :  "default-y" ;       type :  "label" ;       value :  {           type :  "optional" ;           value :  {               max :  number ;               min :  number ;               type :  "float" ;           } ;       } ;  } Readonly label :  "default-y" Readonly type :  "label" Readonly value :  {       type :  "optional" ;       value :  {           max :  number ;           min :  number ;           type :  "float" ;       } ;  } Readonly type :  "optional" Readonly value :  {       max :  number ;       min :  number ;       type :  "float" ;  } Readonly max :  number Readonly min :  number Readonly type :  "float" Readonly font- :  {       type :  "optional" ;       value :  {           pattern :  RegExp ;           type :  "regex" ;           zero :  " " ;       } ;  } Readonly type :  "optional" Readonly value :  {       pattern :  RegExp ;       type :  "regex" ;       zero :  " " ;  } Readonly pattern :  RegExp Readonly type :  "regex" Readonly zero :  " " Readonly font- :  {       type :  "optional" ;       value :  {           choices :  readonly  [ {               choices :  readonly  [ "xx-small" ,  "x-small" ,  "small" ,  "medium" ,  "large" ,  "x-large" ,  "xx-large" ] ;               type :  "choices" ;           } ,  {               max :  number ;               min :  number ;               type :  "float" ;           } ] ;           type :  "choices" ;       } ;  } Readonly type :  "optional" Readonly value :  {       choices :  readonly  [ {           choices :  readonly  [ "xx-small" ,  "x-small" ,  "small" ,  "medium" ,  "large" ,  "x-large" ,  "xx-large" ] ;           type :  "choices" ;       } ,  {           max :  number ;           min :  number ;           type :  "float" ;       } ] ;       type :  "choices" ;  } Readonly choices :  readonly  [ {       choices :  readonly  [ "xx-small" ,  "x-small" ,  "small" ,  "medium" ,  "large" ,  "x-large" ,  "xx-large" ] ;       type :  "choices" ;  } ,  {       max :  number ;       min :  number ;       type :  "float" ;  } ] Readonly type :  "choices" Readonly font- :  {       type :  "optional" ;       value :  {           choices :  readonly  [ "normal" ,  "italic" ] ;           type :  "choices" ;       } ;  } Readonly type :  "optional" Readonly value :  {       choices :  readonly  [ "normal" ,  "italic" ] ;       type :  "choices" ;  } Readonly choices :  readonly  [ "normal" ,  "italic" ] Readonly type :  "choices" Readonly font- :  {       type :  "optional" ;       value :  {           choices :  readonly  [ "normal" ,  "bold" ] ;           type :  "choices" ;       } ;  } Readonly type :  "optional" Readonly value :  {       choices :  readonly  [ "normal" ,  "bold" ] ;       type :  "choices" ;  } Readonly choices :  readonly  [ "normal" ,  "bold" ] Readonly type :  "choices" Readonly relative- :  {       label :  "relative-x" ;       type :  "label" ;       value :  {           type :  "optional" ;           value :  {               max :  number ;               min :  number ;               type :  "float" ;           } ;       } ;  } Readonly label :  "relative-x" Readonly type :  "label" Readonly value :  {       type :  "optional" ;       value :  {           max :  number ;           min :  number ;           type :  "float" ;       } ;  } Readonly type :  "optional" Readonly value :  {       max :  number ;       min :  number ;       type :  "float" ;  } Readonly max :  number Readonly min :  number Readonly type :  "float" Readonly relative- :  {       label :  "relative-y" ;       type :  "label" ;       value :  {           type :  "optional" ;           value :  {               max :  number ;               min :  number ;               type :  "float" ;           } ;       } ;  } Readonly label :  "relative-y" Readonly type :  "label" Readonly value :  {       type :  "optional" ;       value :  {           max :  number ;           min :  number ;           type :  "float" ;       } ;  } Readonly type :  "optional" Readonly value :  {       max :  number ;       min :  number ;       type :  "float" ;  } Readonly max :  number Readonly min :  number Readonly type :  "float" Readonly text :  {       type :  "optional" ;       value :  {           type :  "string" ;       } ;  } Readonly type :  "optional" Readonly value :  {       type :  "string" ;  } Readonly contents :  readonly  [ {       type :  "required" ;       value :  {           label :  "degree-type-value" ;           type :  "label" ;           value :  {               choices :  readonly  [ "add" ,  "alter" ,  "subtract" ] ;               type :  "choices" ;           } ;       } ;  } ] Readonly name :  "degree-type" Static Readonly schema schema :  {       attributes :  {           color :  {               type :  "optional" ;               value :  {                   pattern :  RegExp ;                   type :  "regex" ;                   zero :  "#000000" ;               } ;           } ;           default-x :  {               label :  "default-x" ;               type :  "label" ;               value :  {                   type :  "optional" ;                   value :  {                       max :  number ;                       min :  number ;                       type :  "float" ;                   } ;               } ;           } ;           default-y :  {               label :  "default-y" ;               type :  "label" ;               value :  {                   type :  "optional" ;                   value :  {                       max :  number ;                       min :  number ;                       type :  "float" ;                   } ;               } ;           } ;           font-family :  {               type :  "optional" ;               value :  {                   pattern :  RegExp ;                   type :  "regex" ;                   zero :  " " ;               } ;           } ;           font-size :  {               type :  "optional" ;               value :  {                   choices :  readonly  [ {                       choices :  readonly  [ "xx-small" ,  "x-small" ,  "small" ,  "medium" ,  "large" ,  "x-large" ,  "xx-large" ] ;                       type :  "choices" ;                   } ,  {                       max :  number ;                       min :  number ;                       type :  "float" ;                   } ] ;                   type :  "choices" ;               } ;           } ;           font-style :  {               type :  "optional" ;               value :  {                   choices :  readonly  [ "normal" ,  "italic" ] ;                   type :  "choices" ;               } ;           } ;           font-weight :  {               type :  "optional" ;               value :  {                   choices :  readonly  [ "normal" ,  "bold" ] ;                   type :  "choices" ;               } ;           } ;           relative-x :  {               label :  "relative-x" ;               type :  "label" ;               value :  {                   type :  "optional" ;                   value :  {                       max :  number ;                       min :  number ;                       type :  "float" ;                   } ;               } ;           } ;           relative-y :  {               label :  "relative-y" ;               type :  "label" ;               value :  {                   type :  "optional" ;                   value :  {                       max :  number ;                       min :  number ;                       type :  "float" ;                   } ;               } ;           } ;           text :  {               type :  "optional" ;               value :  {                   type :  "string" ;               } ;           } ;       } ;       contents :  readonly  [ {           type :  "required" ;           value :  {               label :  "degree-type-value" ;               type :  "label" ;               value :  {                   choices :  readonly  [ "add" ,  "alter" ,  "subtract" ] ;                   type :  "choices" ;               } ;           } ;       } ] ;       name :  "degree-type" ;  }  = ... 
Type declaration Readonly attributes :  {       color :  {           type :  "optional" ;           value :  {               pattern :  RegExp ;               type :  "regex" ;               zero :  "#000000" ;           } ;       } ;       default-x :  {           label :  "default-x" ;           type :  "label" ;           value :  {               type :  "optional" ;               value :  {                   max :  number ;                   min :  number ;                   type :  "float" ;               } ;           } ;       } ;       default-y :  {           label :  "default-y" ;           type :  "label" ;           value :  {               type :  "optional" ;               value :  {                   max :  number ;                   min :  number ;                   type :  "float" ;               } ;           } ;       } ;       font-family :  {           type :  "optional" ;           value :  {               pattern :  RegExp ;               type :  "regex" ;               zero :  " " ;           } ;       } ;       font-size :  {           type :  "optional" ;           value :  {               choices :  readonly  [ {                   choices :  readonly  [ "xx-small" ,  "x-small" ,  "small" ,  "medium" ,  "large" ,  "x-large" ,  "xx-large" ] ;                   type :  "choices" ;               } ,  {                   max :  number ;                   min :  number ;                   type :  "float" ;               } ] ;               type :  "choices" ;           } ;       } ;       font-style :  {           type :  "optional" ;           value :  {               choices :  readonly  [ "normal" ,  "italic" ] ;               type :  "choices" ;           } ;       } ;       font-weight :  {           type :  "optional" ;           value :  {               choices :  readonly  [ "normal" ,  "bold" ] ;               type :  "choices" ;           } ;       } ;       relative-x :  {           label :  "relative-x" ;           type :  "label" ;           value :  {               type :  "optional" ;               value :  {                   max :  number ;                   min :  number ;                   type :  "float" ;               } ;           } ;       } ;       relative-y :  {           label :  "relative-y" ;           type :  "label" ;           value :  {               type :  "optional" ;               value :  {                   max :  number ;                   min :  number ;                   type :  "float" ;               } ;           } ;       } ;       text :  {           type :  "optional" ;           value :  {               type :  "string" ;           } ;       } ;  } Readonly color :  {       type :  "optional" ;       value :  {           pattern :  RegExp ;           type :  "regex" ;           zero :  "#000000" ;       } ;  } Readonly type :  "optional" Readonly value :  {       pattern :  RegExp ;       type :  "regex" ;       zero :  "#000000" ;  } Readonly pattern :  RegExp Readonly type :  "regex" Readonly zero :  "#000000" Readonly default- :  {       label :  "default-x" ;       type :  "label" ;       value :  {           type :  "optional" ;           value :  {               max :  number ;               min :  number ;               type :  "float" ;           } ;       } ;  } Readonly label :  "default-x" Readonly type :  "label" Readonly value :  {       type :  "optional" ;       value :  {           max :  number ;           min :  number ;           type :  "float" ;       } ;  } Readonly type :  "optional" Readonly value :  {       max :  number ;       min :  number ;       type :  "float" ;  } Readonly max :  number Readonly min :  number Readonly type :  "float" Readonly default- :  {       label :  "default-y" ;       type :  "label" ;       value :  {           type :  "optional" ;           value :  {               max :  number ;               min :  number ;               type :  "float" ;           } ;       } ;  } Readonly label :  "default-y" Readonly type :  "label" Readonly value :  {       type :  "optional" ;       value :  {           max :  number ;           min :  number ;           type :  "float" ;       } ;  } Readonly type :  "optional" Readonly value :  {       max :  number ;       min :  number ;       type :  "float" ;  } Readonly max :  number Readonly min :  number Readonly type :  "float" Readonly font- :  {       type :  "optional" ;       value :  {           pattern :  RegExp ;           type :  "regex" ;           zero :  " " ;       } ;  } Readonly type :  "optional" Readonly value :  {       pattern :  RegExp ;       type :  "regex" ;       zero :  " " ;  } Readonly pattern :  RegExp Readonly type :  "regex" Readonly zero :  " " Readonly font- :  {       type :  "optional" ;       value :  {           choices :  readonly  [ {               choices :  readonly  [ "xx-small" ,  "x-small" ,  "small" ,  "medium" ,  "large" ,  "x-large" ,  "xx-large" ] ;               type :  "choices" ;           } ,  {               max :  number ;               min :  number ;               type :  "float" ;           } ] ;           type :  "choices" ;       } ;  } Readonly type :  "optional" Readonly value :  {       choices :  readonly  [ {           choices :  readonly  [ "xx-small" ,  "x-small" ,  "small" ,  "medium" ,  "large" ,  "x-large" ,  "xx-large" ] ;           type :  "choices" ;       } ,  {           max :  number ;           min :  number ;           type :  "float" ;       } ] ;       type :  "choices" ;  } Readonly choices :  readonly  [ {       choices :  readonly  [ "xx-small" ,  "x-small" ,  "small" ,  "medium" ,  "large" ,  "x-large" ,  "xx-large" ] ;       type :  "choices" ;  } ,  {       max :  number ;       min :  number ;       type :  "float" ;  } ] Readonly type :  "choices" Readonly font- :  {       type :  "optional" ;       value :  {           choices :  readonly  [ "normal" ,  "italic" ] ;           type :  "choices" ;       } ;  } Readonly type :  "optional" Readonly value :  {       choices :  readonly  [ "normal" ,  "italic" ] ;       type :  "choices" ;  } Readonly choices :  readonly  [ "normal" ,  "italic" ] Readonly type :  "choices" Readonly font- :  {       type :  "optional" ;       value :  {           choices :  readonly  [ "normal" ,  "bold" ] ;           type :  "choices" ;       } ;  } Readonly type :  "optional" Readonly value :  {       choices :  readonly  [ "normal" ,  "bold" ] ;       type :  "choices" ;  } Readonly choices :  readonly  [ "normal" ,  "bold" ] Readonly type :  "choices" Readonly relative- :  {       label :  "relative-x" ;       type :  "label" ;       value :  {           type :  "optional" ;           value :  {               max :  number ;               min :  number ;               type :  "float" ;           } ;       } ;  } Readonly label :  "relative-x" Readonly type :  "label" Readonly value :  {       type :  "optional" ;       value :  {           max :  number ;           min :  number ;           type :  "float" ;       } ;  } Readonly type :  "optional" Readonly value :  {       max :  number ;       min :  number ;       type :  "float" ;  } Readonly max :  number Readonly min :  number Readonly type :  "float" Readonly relative- :  {       label :  "relative-y" ;       type :  "label" ;       value :  {           type :  "optional" ;           value :  {               max :  number ;               min :  number ;               type :  "float" ;           } ;       } ;  } Readonly label :  "relative-y" Readonly type :  "label" Readonly value :  {       type :  "optional" ;       value :  {           max :  number ;           min :  number ;           type :  "float" ;       } ;  } Readonly type :  "optional" Readonly value :  {       max :  number ;       min :  number ;       type :  "float" ;  } Readonly max :  number Readonly min :  number Readonly type :  "float" Readonly text :  {       type :  "optional" ;       value :  {           type :  "string" ;       } ;  } Readonly type :  "optional" Readonly value :  {       type :  "string" ;  } Readonly contents :  readonly  [ {       type :  "required" ;       value :  {           label :  "degree-type-value" ;           type :  "label" ;           value :  {               choices :  readonly  [ "add" ,  "alter" ,  "subtract" ] ;               type :  "choices" ;           } ;       } ;  } ] Readonly name :  "degree-type" 
The
<degree-type>elementParent element:
<degree>The
<degree-type>element indicates if this degree is an addition, alteration, or subtraction relative to the<kind>of the current chord. The value of the<degree-type>element affects the interpretation of the value of the<degree-alter>element.https://www.w3.org/2021/06/musicxml40/musicxml-reference/elements/degree-type/