lotus / node_modules /.cache /ts-loader /3886e06972ee7ecd64df3c3b87647f17.json
k-l-lambda's picture
updated node_modules
4cadbaf
raw
history blame
226 kB
{"remainingRequest":"/home/camus/work/lotus/node_modules/babel-loader/lib/index.js!/home/camus/work/lotus/node_modules/ts-loader/index.js??ref--15-2!/home/camus/work/lotus/node_modules/eslint-loader/index.js??ref--14-0!/home/camus/work/lotus/inc/lilyParser/lilyTerms.ts","dependencies":[{"path":"/home/camus/work/lotus/inc/lilyParser/lilyTerms.ts","mtime":1732184618441},{"path":"/home/camus/work/lotus/node_modules/cache-loader/dist/cjs.js","mtime":1719800821084},{"path":"/home/camus/work/lotus/node_modules/babel-loader/lib/index.js","mtime":1727163989637},{"path":"/home/camus/work/lotus/node_modules/ts-loader/index.js","mtime":1726221607070},{"path":"/home/camus/work/lotus/node_modules/eslint-loader/index.js","mtime":1719800837044}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import { WHOLE_DURATION_MAGNITUDE, FractionNumber, lcmMulti, gcd, MAIN_SCORE_NAME } from "./utils";
import * as idioms from "./idioms";
import { LILYPOND_VERSION } from "../constants";
import * as measureLayout from "../measureLayout";
import ImplicitType from "../lilyNotation/implicitType";
import pick from "../pick";
;
class Locator {
  constructor(term) {
    term._location = term._location || {
      lines: [0, 0],
      columns: [0, 0]
    };
    this.location = term._location;
  }
}
;
class OpenLocator extends Locator {
  set(line, column) {
    this.location.lines[0] = line;
    this.location.columns[0] = column;
  }
}
;
class CloseLocator extends Locator {
  set(line, column) {
    this.location.lines[1] = line;
    this.location.columns[1] = column;
  }
}
;
// concat array of array
const cc = arrays => [].concat(...arrays);
export class MusicChunk {
  constructor(parent, terms = []) {
    this.parent = parent;
    this.terms = terms;
  }
  static join(chunks) {
    return cc(chunks.map((chunk, i) => i === chunks.length - 1 ? chunk.terms : [...chunk.terms, new Divide({})]));
  }
  push(term) {
    this.terms.push(term);
  }
  get size() {
    return this.terms.length;
  }
  get durationMagnitude() {
    return this.terms.reduce((magnitude, term) => magnitude + term.durationMagnitude, 0);
  }
}
;
;
const isNullItem = item => item === "" || item === undefined || item === null || Array.isArray(item) && !item.length;
const compact = items => cc(items.map((item, index) => isNullItem(item) ? [] : [index > 0 ? "\b" : null, item]));
export const getDurationSubdivider = term => {
  if (term instanceof MusicEvent) {
    if (!(term instanceof Rest) || !term.isSpacer) return term.durationValue.subdivider;
  } else if (term instanceof MusicBlock) return lcmMulti(...term.body.map(getDurationSubdivider));else if (term instanceof MusicChunk) return lcmMulti(...term.terms.map(getDurationSubdivider));else if (term instanceof Times || term instanceof Tuplet) {
    const divider = term instanceof Tuplet ? term.divider : term.factor.reciprocal;
    divider.numerator *= getDurationSubdivider(term.music);
    return divider.reduced.numerator;
  } else if (term instanceof Repeat) return getDurationSubdivider(term.bodyBlock);else if (term instanceof Relative) return getDurationSubdivider(term.music);else if (term.isMusic) console.warn("[getDurationSubdivider]	unexpected music term:", term);
  return 1;
};
export const constructMusicFromMeasureLayout = (layout, chunks) => {
  const joinMeasureSeq = seq => MusicChunk.join(seq.map(sublayout => constructMusicFromMeasureLayout(sublayout, chunks)));
  if (layout instanceof measureLayout.SingleMLayout) {
    const chunk = chunks.get(layout.measure);
    console.assert(!!chunk, "no chunk for measure:", layout.measure);
    return chunk;
  } else if (layout instanceof measureLayout.BlockMLayout) {
    const terms = joinMeasureSeq(layout.seq);
    return new MusicChunk(null, terms);
  } else if (layout instanceof measureLayout.VoltaMLayout) {
    const bodyTerms = joinMeasureSeq(layout.body);
    const alternative = layout.alternates && layout.alternates.map(alternate => new MusicBlock({
      body: joinMeasureSeq(alternate)
    }));
    const repeat = Repeat.createVolta(layout.times.toString(), new MusicBlock({
      body: bodyTerms
    }), alternative);
    return new MusicChunk(null, [repeat]);
  } else if (layout instanceof measureLayout.ABAMLayout) {
    const mainList = constructMusicFromMeasureLayout(layout.main, chunks);
    const main = mainList.terms.length === 1 ? mainList.terms[0] : new MusicBlock({
      body: mainList.terms
    });
    const restTerms = joinMeasureSeq(layout.rest);
    const block = new MusicBlock({
      body: [main, ...restTerms]
    });
    return new MusicChunk(null, [new Variable({
      name: "lotusRepeatABA"
    }), block]);
  }
};
export class BaseTerm {
  constructor(data) {
    //Object.assign(this, data);
    for (const key in data) this[key] = parseRaw(data[key]);
  }
  serialize() {
    console.warn("unimplemented serilization:", this);
    return [];
  }
  join() {
    let words = this.serialize().filter(word => ["string", "number"].includes(typeof word)).map(word => word.toString());
    words = words.filter((word, i) => !(i && words[i - 1] === "\n" && word === "\n"));
    let indent = 0;
    const result = [];
    const pop = char => {
      if (!char || result[result.length - 1] === char) {
        result.pop();
        return true;
      }
    };
    for (const word of words) {
      switch (word) {
        case "\b":
          // remove last space
          pop(" ");
          continue;
        case "\b\n":
          // remove last newline
          while (pop("\t")) {}
          pop("\n");
          continue;
        case "\n":
          // no space at line tail
          pop(" ");
      }
      if (/^(\}|>>)/.test(word)) pop("\t"); // remove the last tab
      result.push(word);
      if (/\n$/.test(word)) {
        if (/(\{|<<)\n$/.test(word)) ++indent;else if (/^(\}|>>)/.test(word)) --indent;
        if (indent) result.push(...Array(indent).fill("\t"));
      } else result.push(" ");
    }
    return result.join("");
  }
  relocate(source = this.join()) {
    const words = this.serialize().filter(word => word !== null && word !== undefined && (typeof word !== "string" || /\S/.test(word) && !word.includes("\b"))).map(word => typeof word === "string" ? word.replace(/\n/g, "") : word);
    const chars = source.split("");
    let line = 1;
    let column = 0;
    let wordIndex = 0;
    for (let i = 0; i < chars.length; ++i) {
      if (wordIndex >= words.length) break;
      const char = chars[i];
      switch (char) {
        case "\n":
          ++line;
          column = 0;
          break;
        case " ":
        case "\t":
          ++column;
          break;
        default:
          let word = words[wordIndex];
          while (word instanceof Locator) {
            word.set(line, column);
            ++wordIndex;
            word = words[wordIndex];
          }
          if (wordIndex >= words.length) break;
          word = word.toString();
          if (char === word[0]) {
            i += word.length - 1;
            column += word.length;
            ++wordIndex;
          } else {
            //debugger;
            throw new Error(`unexpected char in source: [${i}]'${char}', expect: ${word}`);
          }
      }
    }
  }
  clone() {
    return parseRaw(JSON.parse(JSON.stringify(this)));
  }
  get entries() {
    return null;
  }
  get isMusic() {
    return false;
  }
  get musicChunks() {
    if (!this.isMusic || !this.entries) return [];
    return [].concat(...this.entries.map(entry => entry.musicChunks));
  }
  get measures() {
    const indices = [this._measure].concat(...(this.entries || []).map(entry => entry.measures)).filter(index => Number.isInteger(index));
    return Array.from(new Set(indices));
  }
  get durationMagnitude() {
    return 0;
  }
  get proto() {
    return termProtoMap.get(Object.getPrototypeOf(this));
  }
  get href() {
    if (this._location) return `${this._location.lines[0]}:${this._location.columns[0]}:${this._location.columns[1]}`;
    return null;
  }
  get measureLayout() {
    return null;
  }
  getField(key) {
    console.assert(!!this.entries, "[BaseTerm.getField] term's entries is null:", this);
    for (const entry of this.entries) {
      const result = entry.query(key);
      if (result) return result;
    }
  }
  query(key) {
    void key;
    //console.warn("term.query not implemented:", this);
  }
  appendAssignment(key, value) {
    console.assert(!!this.entries, "no entries on this term.");
    const assign = this.getField(key);
    if (assign) assign.value = value;else {
      this.entries.push(parseRaw({
        proto: "Assignment",
        key,
        value: value
      }));
    }
  }
  findFirst(condition) {
    if (!this.entries) return null;
    if (BaseTerm.isPrototypeOf(condition)) {
      const termClass = condition;
      condition = term => term instanceof termClass;
    }
    for (const entry of this.entries) {
      if (condition(entry)) return entry;
      if (entry instanceof BaseTerm) {
        const result = entry.findFirst(condition);
        if (result) return result;
      }
    }
  }
  findLast(condition) {
    if (!this.entries) return null;
    if (BaseTerm.isPrototypeOf(condition)) {
      const termClass = condition;
      condition = term => term instanceof termClass;
    }
    const reversedEntries = [...this.entries];
    reversedEntries.reverse();
    for (const entry of reversedEntries) {
      if (condition(entry)) return entry;
      if (entry instanceof BaseTerm) {
        const result = entry.findLast(condition);
        if (result) return result;
      }
    }
  }
  findAll(condition) {
    if (!this.entries) return [];
    if (BaseTerm.isPrototypeOf(condition)) {
      const termClass = condition;
      condition = term => term instanceof termClass;
    }
    const result = [];
    for (const entry of this.entries) {
      if (condition(entry)) result.push(entry);
      if (entry instanceof BaseTerm) result.push(...entry.findAll(condition));
    }
    return result;
  }
  forEachTerm(termClass, handle) {
    if (!this.entries) return;
    for (const entry of this.entries) {
      if (entry instanceof termClass) handle(entry);
      if (entry instanceof BaseTerm) entry.forEachTerm(termClass, handle);
    }
  }
  forEachTopTerm(termClass, handle) {
    if (!this.entries) return;
    for (const entry of this.entries) {
      if (entry instanceof termClass) handle(entry);else if (entry instanceof BaseTerm) entry.forEachTopTerm(termClass, handle);
    }
  }
  toJSON() {
    // exlude meta fields in JSON
    const fields = Object.keys(this).filter(key => !/^_/.test(key));
    const data = pick(this, fields);
    Object.entries(data).forEach(([key, value]) => {
      if (value && typeof value === "object" && !Array.isArray(value) && !(value instanceof BaseTerm)) data[key] = {
        proto: "_PLAIN",
        ...value
      };
    });
    return {
      proto: this.proto,
      ...data
    };
  }
  static isTerm(x) {
    return typeof x === "object" && x instanceof BaseTerm;
  }
  static optionalSerialize(item) {
    //return BaseTerm.isTerm(item) ? (item as BaseTerm).serialize() : (item === undefined ? [] : [item]);
    if (!BaseTerm.isTerm(item)) return item === undefined ? [] : [item];
    return [...BaseTerm.optionalSerialize(item._headComment), ...item.serialize(), ...(item._tailComment ? ["\b\n", "\t"] : []), ...BaseTerm.optionalSerialize(item._tailComment)];
  }
  static serializeScheme(item) {
    if (typeof item === "boolean") item = item ? "#t" : "#f";
    return BaseTerm.optionalSerialize(item);
  }
}
export class Root extends BaseTerm {
  serialize() {
    return cc(this.sections.map(section => [...BaseTerm.optionalSerialize(section), "\n\n"]));
  }
  get entries() {
    return this.sections;
  }
  getBlock(head) {
    return this.entries.find(entry => entry.head === head || entry.head === "\\" + head);
  }
  get includeFiles() {
    return this.sections.filter(section => section instanceof Include).map(include => include.filename);
  }
  static priorityForSection(term) {
    if (term instanceof Version) return 0;
    if (term instanceof Language) return 1;
    if (term instanceof Scheme) return 3;
    if (term instanceof Assignment) return 7;
    if (term instanceof Block) {
      switch (term.head) {
        case "\\header":
          return 2;
        case "\\paper":
          return 4;
        case "\\layout":
          return 5;
        case "\\score":
          return 10;
      }
    }
    return Infinity;
  }
  reorderSections() {
    this.sections.sort((s1, s2) => Root.priorityForSection(s1) - Root.priorityForSection(s2));
  }
}
;
export class Primitive extends BaseTerm {
  serialize() {
    return [this.exp];
  }
}
;
export class LiteralString extends BaseTerm {
  static fromString(content) {
    return new LiteralString({
      exp: JSON.stringify(content)
    });
  }
  serialize() {
    return [this.exp];
  }
  toString() {
    try {
      return eval(this.exp);
    } catch (err) {
      console.warn("invalid lilypond string exp:", this.exp);
      return this.exp;
    }
  }
}
;
export class Command extends BaseTerm {
  constructor(data) {
    super(data);
    this.args.forEach(term => {
      if (term instanceof MusicBlock || term instanceof Block) term._parent = this;
    });
  }
  static createSet(key, value) {
    return new Command({
      cmd: "set",
      args: [new Assignment({
        key,
        value
      })]
    });
  }
  serialize() {
    return ["\\" + this.cmd, ...[].concat(...this.args.map(BaseTerm.optionalSerialize)), ["break", "pageBreak", "overrideProperty"].includes(this.cmd) ? "\n" : null];
  }
  get entries() {
    return this.args.filter(arg => arg instanceof BaseTerm);
  }
  get isMusic() {
    return this.args.some(arg => arg.isMusic);
  }
  get musicChunks() {
    if (this.cmd === "alternative") return [].concat(...this.args[0].body.map(term => term.musicChunks));
    return [].concat(...this.entries.map(entry => entry.musicChunks));
  }
  get isRepeatWithAlternative() {
    return this.cmd === "repeat" && this.args[2] instanceof MusicBlock && this.args[3] && this.args[3].cmd === "alternative";
  }
  get durationMagnitude() {
    switch (this.cmd) {
      // TODO: refine this in Times
      case "times":
        {
          const factor = eval(this.args[0]);
          return this.args[1].durationMagnitude * factor;
        }
      // TODO: refine this in Tuplet
      case "tuplet":
        {
          const factor = 1 / eval(this.args[0]);
          return this.args[this.args.length - 1].durationMagnitude * factor;
        }
      case "afterGrace":
        return this.args[0].durationMagnitude;
      default:
        if (this instanceof Grace) return 0;
        return this.args.filter(arg => arg instanceof BaseTerm).reduce((magnitude, term) => magnitude + term.durationMagnitude, 0);
    }
  }
  get measureLayout() {
    const args = [...this.args].reverse();
    for (const arg of args) {
      const layout = arg instanceof BaseTerm && arg.measureLayout;
      if (layout) return layout;
    }
    return null;
  }
  getAssignmentPair() {
    if (this.args[0] instanceof Assignment) return {
      key: this.args[0].key,
      value: this.args[0].value
    };
    if (this.args[1] instanceof Assignment) return {
      key: this.args[0],
      value: this.args[1].value
    };
    if (typeof this.args[0] === "string") return {
      key: this.args[0],
      value: ""
    };
    return null;
  }
}
;
export class Variable extends Command {
  constructor({
    name
  }) {
    super({
      cmd: name,
      args: []
    });
    this.name = name;
  }
  toJSON() {
    return {
      proto: this.proto,
      name: this.name
    };
  }
  queryValue(dict) {
    const field = dict.getField(this.name);
    return field && field.value;
  }
  get isMusic() {
    if ([MAIN_SCORE_NAME].includes(this.name)) return true;
    return false;
  }
}
;
export class MarkupCommand extends Command {
  toString() {
    const strs = [];
    this.forEachTerm(LiteralString, term => strs.push(term.toString()));
    return strs.join("\n");
  }
}
;
export class Repeat extends Command {
  static createVolta(times, body, alternative) {
    const args = ["volta", times, body];
    if (alternative) {
      args.push(new Command({
        cmd: "alternative",
        args: [new MusicBlock({
          body: alternative
        })]
      }));
    }
    return new Repeat({
      cmd: "repeat",
      args
    });
  }
  get type() {
    return this.args[0];
  }
  get times() {
    return Number(this.args[1]);
  }
  get bodyBlock() {
    return this.args[2];
  }
  get alternativeBlocks() {
    return this.args[3] && this.args[3].args[0].body;
  }
  // this result length equal to times, if not null
  get completeAlternativeBlocks() {
    if (!this.alternativeBlocks || !this.alternativeBlocks.length) return null;
    if (this.alternativeBlocks.length >= this.times) return this.alternativeBlocks.slice(0, this.times);
    const list = [];
    for (let i = 0; i < this.times - this.alternativeBlocks.length; ++i) list.push(this.alternativeBlocks[0]);
    list.push(...this.alternativeBlocks);
    return list;
  }
  get measureLayout() {
    switch (this.type) {
      case "volta":
        {
          const layout = new measureLayout.VoltaMLayout();
          layout.times = this.times;
          layout.body = this.bodyBlock.measureLayout.seq;
          layout.alternates = this.alternativeBlocks && this.alternativeBlocks.map(block => block.measureLayout.seq);
          return layout;
        }
      case "tremolo":
        return this.bodyBlock.measureLayout;
      default:
        console.warn("unsupported repeat type:", this.type);
    }
    return null;
  }
  // for tremolo
  get sumDuration() {
    if (this.bodyBlock instanceof MusicEvent) return Duration.fromMagnitude(this.args[2].durationMagnitude * this.times);else if (this.bodyBlock instanceof MusicBlock) {
      const events = this.bodyBlock.body.filter(term => term instanceof MusicEvent);
      const magnitude = events.reduce((m, event) => m + event.durationMagnitude, 0) * this.times;
      return Duration.fromMagnitude(magnitude);
    }
    return null;
  }
  get singleTremolo() {
    if (this.type === "tremolo") {
      if (this.bodyBlock instanceof MusicEvent) return true;
      if (this.bodyBlock instanceof MusicBlock) {
        const events = this.bodyBlock.body.filter(term => term instanceof MusicEvent);
        return events.length === 1;
      }
    }
    return false;
  }
  // \repeat {body} \alternative {{alter1} {alter2}}		=> body alter1 body alter2
  getUnfoldTerms() {
    const completeAlternativeBlocks = this.completeAlternativeBlocks;
    const list = [];
    for (let i = 0; i < this.times; ++i) {
      list.push(...this.bodyBlock.clone().body);
      if (completeAlternativeBlocks) list.push(...completeAlternativeBlocks[i].clone().body);
    }
    return list;
  }
  // \repeat {body} \alternative {{alter1} {alter2}}		=> body alter1 alter2
  getPlainTerms() {
    const list = [...this.bodyBlock.clone().body];
    const alternativeBlocks = this.alternativeBlocks;
    if (alternativeBlocks) alternativeBlocks.forEach(block => list.push(...block.clone().body));
    return list;
  }
  // \repeat {body} \alternative {{alter1} {alter2}}		=> body alter2
  getTailPassTerms() {
    const list = [...this.bodyBlock.clone().body];
    const alternativeBlocks = this.alternativeBlocks;
    if (alternativeBlocks) list.push(...alternativeBlocks[alternativeBlocks.length - 1].clone().body);
    return list;
  }
}
;
export class Relative extends Command {
  static makeBlock(block, {
    anchor
  } = {}) {
    if (!anchor) {
      const chord = block.findFirst(Chord);
      anchor = chord && chord.anchorPitch;
    }
    return new Relative({
      cmd: "relative",
      args: [anchor, block].filter(term => term)
    });
  }
  get anchor() {
    if (this.args[0] instanceof ChordElement) return this.args[0];
    return null;
  }
  get music() {
    return this.args[this.args.length - 1];
  }
  get headChord() {
    return this.findFirst(Chord);
  }
  get tailPitch() {
    const tail = this.findLast(Chord);
    return tail && tail.absolutePitch;
  }
  // with side effect
  shiftBody(newAnchor) {
    const headChord = this.headChord;
    if (newAnchor && headChord) {
      headChord.shiftAnchor(newAnchor);
      headChord._anchorPitch = null;
      //console.log("shiftAnchor.post:", headChord.join(), headChord);
    }
    const music = this.music;
    if (music instanceof MusicBlock) {
      //music.clearPitchCache();
      return music.body;
    }
    return [music];
  }
}
export class ParallelMusic extends Command {
  get varNames() {
    return this.args[0].exp.value.asList;
  }
  get body() {
    return this.args[1];
  }
  get voices() {
    const voiceNames = this.varNames;
    const chunks = this.body.musicChunks;
    const measureCount = Math.ceil(chunks.length / voiceNames.length);
    return voiceNames.map((name, index) => ({
      name: name.toString(),
      body: Array(measureCount).fill(null).map((_, m) => chunks[m * voiceNames.length + index]).filter(Boolean)
    }));
  }
}
;
export class TimeSignature extends Command {
  get value() {
    return FractionNumber.fromExpression(this.args[0]);
  }
}
;
export class Partial extends Command {
  get duration() {
    return this.args[0];
  }
}
;
export class Times extends Command {
  get factor() {
    return FractionNumber.fromExpression(this.args[0]);
  }
  get music() {
    return this.args[this.args.length - 1];
  }
}
;
export class Tuplet extends Command {
  get divider() {
    return FractionNumber.fromExpression(this.args[0]);
  }
  get music() {
    return this.args[this.args.length - 1];
  }
}
;
export class Grace extends Command {
  get music() {
    return this.args[this.args.length - 1];
  }
}
;
export class AfterGrace extends Command {
  get body() {
    return this.args[0];
  }
  get grace() {
    return this.args[1];
  }
  get measureLayout() {
    return measureLayout.BlockMLayout.fromSeq([this.body.measureLayout, this.grace.measureLayout]);
  }
}
;
export class Clef extends Command {
  get clefName() {
    return this.args[0].toString();
  }
}
;
export class KeySignature extends Command {
  get keyPitch() {
    return new ChordElement({
      pitch: this.args[0],
      options: {
        proto: "_PLAIN"
      }
    });
  }
  get key() {
    const keyPitch = this.keyPitch;
    const minor = this.args[1] === "\\minor";
    const phonetOrder = idioms.FIFTH_PHONETS.indexOf(keyPitch.phonet);
    return phonetOrder + (minor ? -4 : -1) + keyPitch.alterValue * 7;
  }
}
;
export class OctaveShift extends Command {
  get value() {
    return this.args[0].exp;
  }
}
;
export class Include extends Command {
  static create(filename) {
    return new Include({
      cmd: "include",
      args: [LiteralString.fromString(filename)]
    });
  }
  get filename() {
    return this.args[0].toString();
  }
}
;
export class Version extends Command {
  static get default() {
    return new Version({
      cmd: "version",
      args: [LiteralString.fromString(LILYPOND_VERSION)]
    });
  }
  get version() {
    return this.args[0].toString();
  }
}
;
export class Language extends Command {
  static make(language) {
    return new Language({
      cmd: "language",
      args: [LiteralString.fromString(language)]
    });
  }
  get language() {
    return this.args[0].toString();
  }
}
;
export class LyricMode extends Command {
  get block() {
    return this.args[0];
  }
}
;
export class ChordMode extends Command {
  get block() {
    return this.args[0];
  }
}
;
export class Transposition extends Command {
  get transposition() {
    return this.args[0].pitchValue - 60;
  }
}
;
export class StemDirection extends Command {
  get direction() {
    return this.cmd.substr(4);
  }
}
;
export class Change extends Command {
  get key() {
    return this.args[0].toString();
  }
  get value() {
    return this.args[1].toString();
  }
}
;
export class Block extends BaseTerm {
  constructor(data) {
    super(data);
    this.body = this.body.map(parseRawEnforce);
  }
  serialize() {
    const heads = Array.isArray(this.head) ? this.head : this.head ? [this.head] : [];
    return [...heads, "{\n", ...cc(this.body.map(section => [...BaseTerm.optionalSerialize(section), "\n"])), "}\n"];
  }
  get entries() {
    return this.body;
  }
  get isMIDIDedicated() {
    const subBlocks = this.body.filter(term => term instanceof Block);
    return subBlocks.some(term => term.head === "\\midi") && !subBlocks.some(term => term.head === "\\layout");
  }
  get assignmentDict() {
    const assignments = this.body.filter(term => term instanceof Assignment);
    return assignments.reduce((dict, assignment) => (dict[assignment.key.toString()] = assignment.value.toString(), dict), {});
  }
}
;
export class InlineBlock extends Block {
  serialize() {
    return ["{", ...cc(this.body.map(BaseTerm.optionalSerialize)), "}"];
  }
}
;
export class MusicBlock extends BaseTerm {
  constructor(data) {
    super(data);
    this.body = this.body.map(parseRawEnforce);
  }
  static fromTerms(terms) {
    const block = new MusicBlock({
      body: [...terms]
    });
    block.clarifyHead();
    return block;
  }
  serialize() {
    return ["{\n", ...cc(this.body.map(BaseTerm.optionalSerialize)), "\n", "}\n"];
  }
  clone() {
    if (this._parent) {
      const parent = this._parent.clone();
      const block = parent.findFirst(MusicBlock);
      console.assert(block && block._parent === parent, "invalid block-parent relation", parent, block);
      return block;
    }
    return BaseTerm.prototype.clone.call(this);
  }
  get entries() {
    return this.body;
  }
  get isMusic() {
    return true;
  }
  get musicChunks() {
    const chunks = [];
    let currentChunk = new MusicChunk(this);
    const dumpChunk = () => {
      if (currentChunk.size) chunks.push(currentChunk);
      currentChunk = new MusicChunk(this);
    };
    for (const term of this.entries) {
      if (term instanceof Repeat) {
        dumpChunk();
        chunks.push(...term.musicChunks);
      } else if (term instanceof Divide) dumpChunk();else currentChunk.push(term);
    }
    dumpChunk();
    return chunks;
  }
  // [deprecated]
  // for parallelMusic only
  get voiceNames() {
    const header = this._parent;
    if (header && header.cmd === "parallelMusic") {
      if (header.args[0] instanceof Scheme && header.args[0].exp instanceof SchemePointer && header.args[0].exp.value instanceof SchemeFunction) {
        const voices = header.args[0].exp.value.asList;
        return voices;
      }
    }
    return null;
  }
  // [deprecated]
  get voices() {
    const voiceNames = this.voiceNames;
    if (!voiceNames) return [{
      body: this.musicChunks
    }];
    const chunks = this.musicChunks;
    const measureCount = Math.ceil(chunks.length / voiceNames.length);
    return voiceNames.map((name, index) => ({
      name: name.toString(),
      body: Array(measureCount).fill(null).map((_, m) => chunks[m * voiceNames.length + index]).filter(chunk => chunk)
    }));
  }
  get durationMagnitude() {
    return this.body.reduce((magnitude, term) => magnitude + term.durationMagnitude, 0);
  }
  get isRelative() {
    return this._parent instanceof Relative;
  }
  get anchorPitch() {
    if (this.isRelative) return this._parent.anchor;
    return null;
  }
  get measures() {
    // make a continouse indices list
    const subterms = this.findAll(term => term.isMusic);
    const subIndices = [].concat(...subterms.map(term => term.measures)).filter(index => Number.isInteger(index));
    if (!subIndices.length) return [];
    const min = Math.min(...subIndices);
    const max = Math.max(...subIndices);
    return Array(max + 1 - min).fill(null).map((_, i) => i + min);
  }
  get notes() {
    const notes = this.body.filter(term => term instanceof Chord && !term.isRest);
    this.forEachTopTerm(MusicBlock, block => notes.push(...block.notes));
    return notes;
  }
  get sonicNotes() {
    return this.notes.filter(note => !note.completeTied);
  }
  get noteTicks() {
    const ticks = this.sonicNotes.map(note => note._tick);
    return Array.from(new Set(ticks)).sort((t1, t2) => t1 - t2);
  }
  get measureTicks() {
    const tickTable = {};
    this.body.forEach(term => {
      if (Number.isFinite(term._measure) && Number.isFinite(term._tick)) {
        if (!Number.isFinite(tickTable[term._measure])) tickTable[term._measure] = term._tick;
      }
    });
    return Object.entries(tickTable).map(([measure, tick]) => [Number(measure), tick]);
  }
  get measureLayout() {
    const seq = this.body.filter(term => term.isMusic).map(term => term.measureLayout).filter(Boolean);
    if (this._functional === "lotusRepeatABA") {
      const [main, ...rest] = seq;
      const layout = new measureLayout.ABAMLayout();
      layout.main = main;
      layout.rest = measureLayout.BlockMLayout.trimSeq(rest);
      return layout;
    }
    return measureLayout.BlockMLayout.fromSeq(seq);
  }
  get measureChunkMap() {
    const map = new Map();
    this.body.forEach(term => {
      if (Number.isInteger(term._measure) && !(term instanceof Divide)) {
        if (!map.get(term._measure)) map.set(term._measure, new MusicChunk(this));
        const chunk = map.get(term._measure);
        chunk.terms.push(term);
      }
    });
    return map;
  }
  clearPitchCache() {
    this.forEachTerm(ChordElement, pitch => {
      pitch._absolutePitch = null;
      //pitch._previous = null;
    });
  }
  updateChordAnchors() {
    const chord = this.findFirst(Chord);
    if (chord) chord._anchorPitch = chord._anchorPitch || this.anchorPitch;
    this.clearPitchCache();
  }
  // deprecated
  updateChordChains() {
    let previous = null;
    this.updateChordAnchors();
    this.forEachTerm(MusicBlock, block => block.updateChordAnchors());
    this.forEachTerm(MusicEvent, event => {
      event._previous = previous;
      previous = event;
    });
  }
  // with side effect
  spreadRepeatBlocks({
    ignoreRepeat = true,
    keepTailPass = false
  } = {}) {
    this.forEachTerm(MusicBlock, block => block.spreadRepeatBlocks());
    this.body = cc(this.body.map(term => {
      if (term instanceof Repeat) {
        if (!ignoreRepeat) return term.getUnfoldTerms();else if (keepTailPass) return term.getTailPassTerms();else return term.getPlainTerms();
      } else return [term];
    }));
    return this;
  }
  /*// with side effect
  spreadRelativeBlocks (): this {
      this.forEachTerm(MusicBlock, block => block.spreadRelativeBlocks());
       let anchorPitch = null;
       this.body = cc(this.body.map(term => {
          if (term instanceof Relative) {
              const list = term.shiftBody(anchorPitch);
               anchorPitch = term.tailPitch || anchorPitch;
               return list;
          }
          else
              return [term];
      }));
       return this;
  }*/
  // with side effect
  unfoldDurationMultipliers() {
    let timeDenominator = 4;
    const unfoldMultipliers = term => {
      if (term instanceof TimeSignature) timeDenominator = term.value.denominator;
      if (!(term instanceof MusicEvent) || !term.duration || !term.duration.multipliers || !term.duration.multipliers.length) return [term];
      const factor = term.duration.multipliers.reduce((factor, multiplier) => factor * Number(multiplier), 1);
      if (!Number.isInteger(factor) || factor <= 0) return [term];
      const denominator = Math.max(term.duration.denominator, timeDenominator);
      const event = term.clone();
      event.duration.multipliers = [];
      // break duration into multiple rest events
      const restCount = event.duration.magnitude / WHOLE_DURATION_MAGNITUDE * (factor - 1) * denominator;
      if (!Number.isInteger(restCount)) console.warn("Rest count is not integear:", restCount, denominator, event.duration.magnitude, factor);
      const rests = Array(Math.floor(restCount)).fill(null).map(() => new Rest({
        name: "s",
        duration: new Duration({
          number: denominator,
          dots: 0
        })
      }));
      return [event, ...rests];
    };
    this.body = cc(this.body.map(unfoldMultipliers));
    return this;
  }
  /*// pure
  flatten ({spreadRepeats = false} = {}): Relative {
      this.updateChordChains();
       const chord = this.findFirst(Chord) as Chord;
      const anchor = this.anchorPitch || (chord && chord.anchorPitch);
       const block = this.clone();
      if (spreadRepeats)
          block.spreadRepeatBlocks();
      block.spreadRelativeBlocks();
      block.unfoldDurationMultipliers();
       return Relative.makeBlock(block, {anchor: anchor && anchor.clone()});
  }*/
  // with side effect
  expandVariables(dict) {
    this.body = this.body.map(term => {
      if (term instanceof Variable) {
        const value = term.queryValue(dict);
        const clonedValue = value instanceof BaseTerm ? value.clone() : value;
        if (clonedValue instanceof BaseTerm) {
          clonedValue.forEachTerm(MusicBlock, block => block.expandVariables(dict));
          if (clonedValue instanceof MusicBlock) clonedValue.expandVariables(dict);
        }
        return clonedValue;
      }
      return term;
    });
    return this;
  }
  // with side effects
  redivide({
    recursive = true,
    measureHeads = null
  } = {}) {
    if (recursive) {
      this.forEachTerm(MusicBlock, block => {
        if (!block._parent || block._parent.cmd !== "alternative") block.redivide({
          recursive,
          measureHeads
        });
      });
    }
    // split rests
    if (measureHeads) {
      this.body = [].concat(...this.body.map(term => {
        if (!(term instanceof Rest) || term.name !== "s" || !Number.isInteger(term._measure)) return [term];
        const nextHead = measureHeads[term._measure];
        const endTick = term._tick + term.durationMagnitude;
        if (nextHead > 0 && endTick > nextHead) {
          const post_events = term.post_events;
          let startTick = term._tick;
          const rests = [];
          let nextMeasure;
          for (nextMeasure = term._measure; nextMeasure < measureHeads.length && endTick > measureHeads[nextMeasure]; ++nextMeasure) {
            const duration = Duration.fromMagnitude(measureHeads[nextMeasure] - startTick);
            if (!duration) {
              console.warn("invalid middle rest duration, splitting gave up:", measureHeads[nextMeasure] - startTick, term);
              return [term];
            }
            const rest = new Rest({
              name: "s",
              duration,
              post_events: []
            });
            rest._measure = nextMeasure;
            rest._lastMeasure = nextMeasure;
            rests.push(rest);
            console.assert(!!rest.duration, "middle splitted rest duration invalid:", measureHeads[nextMeasure] - startTick);
            startTick = measureHeads[nextMeasure];
          }
          const duration = Duration.fromMagnitude(endTick - startTick);
          if (!duration) {
            console.warn("invalid tail rest duration, splitting gave up:", endTick - startTick, term);
            return [term];
          }
          const rest = new Rest({
            name: "s",
            duration,
            post_events: post_events && [...post_events]
          });
          rest._measure = nextMeasure;
          rest._lastMeasure = nextMeasure;
          rests.push(rest);
          console.assert(rests.reduce((sum, rest) => sum + rest.durationMagnitude, 0) === term.durationMagnitude, "duration splitting error:", rests, term);
          //if (rests.reduce((sum, rest) => sum + rest.durationMagnitude, 0) !== term.durationMagnitude)
          //	debugger;
          return rests;
        }
        return [term];
      }));
    }
    const isPostTerm = term => !term || term instanceof PostEvent || term.exp === "~" || ["bar", "arpeggio", "glissando", "sustainOff", "sustainOn"].includes(term.cmd);
    const list = this.body.filter(term => !(term instanceof Divide));
    let measure = null;
    for (const term of list) {
      if (Number.isInteger(measure) && isPostTerm(term)) term._measure = measure;else measure = term._measure;
    }
    const body = [];
    const measures = new Set();
    list.reverse().forEach(term => {
      if (term instanceof BaseTerm) {
        const newMeasures = term.measures.filter(m => !measures.has(m));
        if (newMeasures.length) {
          const comment = " " + newMeasures[0] + (newMeasures.length > 1 ? "-" + Math.max(...newMeasures) : "");
          if (body.length) body.push(new Divide({
            _tailComment: Comment.createSingle(comment)
          }));
          newMeasures.forEach(m => measures.add(m));
        }
      }
      body.push(term);
    });
    this.body = body.reverse();
  }
  clarifyHead() {
    const terms = this.body;
    const head = terms.find(term => term.isMusic);
    if (head instanceof MusicEvent) {
      // clarify the first music event content
      const firstEventIndex = terms.indexOf(head);
      if (firstEventIndex >= 0) {
        const firstEvent = terms[firstEventIndex];
        //console.log("firstEvent:", firstEvent);
        if (firstEvent._previous) {
          const clarified = firstEvent.clarified;
          terms.splice(firstEventIndex, 1, clarified);
          //console.log("terms:", firstEventIndex, terms, clarified);
        }
      }
    } else if (head) {
      const block = head.findFirst(MusicBlock);
      if (block) block.clarifyHead();else console.warn("[MusicBlock.clarifyHead] unexpected music head:", head);
    }
  }
  absoluteToRelative() {
    const anchor = this.findFirst(Chord);
    if (!anchor) return null;
    const anchorPitch = anchor.absolutePitch;
    let pitch = anchorPitch;
    const newBody = this.clone();
    newBody.forEachTerm(Chord, chord => {
      const newPitch = chord.absolutePitch;
      chord.makeRelativeTo(pitch);
      pitch = newPitch;
    });
    return Relative.makeBlock(newBody, {
      anchor: anchorPitch
    });
  }
}
;
export class SimultaneousList extends BaseTerm {
  serialize() {
    return ["<<\n", ...cc(this.list.map(item => [...BaseTerm.optionalSerialize(item), "\n"])), ">>\n"];
  }
  removeStaffGroup() {
    for (let i = 0; i < this.list.length; ++i) {
      const item = this.list[i];
      if (item.head instanceof Command && item.head.args && item.head.args[0] === "StaffGroup") this.list[i] = item.body;
    }
    this.list.forEach(item => {
      if (item instanceof SimultaneousList) item.removeStaffGroup();
    });
  }
  get isMusic() {
    return true;
  }
  get entries() {
    return this.list;
  }
  get durationMagnitude() {
    return Math.max(...this.list.filter(term => term instanceof BaseTerm).map(term => term.durationMagnitude));
  }
  get measureLayout() {
    const track = this.list.find(term => term instanceof BaseTerm && term.measureLayout);
    return track && track.measureLayout;
  }
}
;
export class ContextedMusic extends BaseTerm {
  serialize() {
    return [...BaseTerm.optionalSerialize(this.head), ...BaseTerm.optionalSerialize(this.body), ...BaseTerm.optionalSerialize(this.lyrics)];
  }
  get isMusic() {
    return true;
  }
  get entries() {
    return [this.head, this.body];
  }
  get type() {
    return this.head.args[0];
  }
  get durationMagnitude() {
    return this.body.durationMagnitude;
  }
  get withClause() {
    if (this.head.args[2] && this.head.args[2] instanceof Command && this.head.args[2].cmd === "with") return this.head.args[2];
  }
  get contextDict() {
    const withEntries = this.withClause ? Object.entries(this.withClause.args[0].assignmentDict) : [];
    const entries = withEntries.map(([key, value]) => [`${this.type}.${key}`, value]);
    const pair = this.head.getAssignmentPair();
    if (pair) entries.push([pair.key.toString(), pair.value.toString()]);
    return entries.reduce((dict, [key, value]) => (dict[key] = value, dict), {});
  }
  get list() {
    if (this.body instanceof SimultaneousList) return this.body.list;
    return null;
  }
  set list(value) {
    if (this.body instanceof SimultaneousList) this.body.list = value;
  }
  get measureLayout() {
    return this.body.measureLayout;
  }
}
;
export class Divide extends BaseTerm {
  serialize() {
    return ["|", "\n"];
  }
}
export class Scheme extends BaseTerm {
  serialize() {
    if (BaseTerm.isTerm(this.exp)) return ["#", "\b", ...this.exp.serialize()];else if (typeof this.exp === "boolean") return ["#", "\b", this.exp ? "#t" : "#f"];
    // TODO: enhance grammar to parse empty scheme list
    //else if (this.exp === null)
    //	return ["#", "\b", "'()"];
    else return ["#", "\b", this.exp];
  }
  query(key) {
    if (this.exp instanceof SchemeFunction) return this.exp.query(key);
  }
  get entries() {
    if (this.exp instanceof BaseTerm) return [this.exp];
    return [];
  }
}
;
export class SchemeFunction extends BaseTerm {
  serialize() {
    return ["(", "\b", ...BaseTerm.optionalSerialize(this.func), ...cc(this.args.map(BaseTerm.serializeScheme)), "\b", ")"];
  }
  query(key) {
    if (key === this.func) {
      const term = this;
      return {
        get value() {
          return term.args.length === 1 ? term.args[0] : term.args;
        },
        set value(value) {
          if (term.args.length === 1) term.args[0] = value;else term.args = value;
        }
      };
    }
  }
  get asList() {
    return [this.func, ...this.args];
  }
  get entries() {
    return this.asList.filter(term => term instanceof BaseTerm);
  }
}
;
export class SchemePair extends BaseTerm {
  serialize() {
    return ["(", "\b", ...BaseTerm.optionalSerialize(this.left), ".", ...BaseTerm.optionalSerialize(this.right), "\b", ")"];
  }
}
;
export class SchemePointer extends BaseTerm {
  serialize() {
    const content = this.value === null ? ["()"] : BaseTerm.optionalSerialize(this.value);
    return ["'", "\b", ...content];
  }
  get entries() {
    if (this.value instanceof BaseTerm) return [this.value];
    return [];
  }
}
;
export class SchemeEmbed extends BaseTerm {
  serialize() {
    return ["#{", ...BaseTerm.optionalSerialize(this.value), "#}"];
  }
}
;
export class Assignment extends BaseTerm {
  constructor(data) {
    super(data);
    if (this.value instanceof BaseTerm) this.value._parent = this;
  }
  serialize() {
    const keys = (Array.isArray(this.key) ? this.key : [this.key]).map(BaseTerm.optionalSerialize);
    const values = (Array.isArray(this.value) ? this.value : [this.value]).map(BaseTerm.optionalSerialize);
    return [...cc(keys), "=", ...cc(values)];
  }
  get entries() {
    if (this.value instanceof BaseTerm) return [this.value];
    return null;
  }
  query(key) {
    if (this.key === key) {
      const term = this;
      return {
        get value() {
          return term.value;
        },
        set value(value) {
          term.value = value;
        }
      };
    }
  }
}
;
export class MusicEvent extends BaseTerm {
  constructor(data) {
    super(data);
    if (this.post_events) this.post_events = this.post_events.map(parseRaw);
  }
  getPreviousT(T) {
    if (this._previous instanceof T) return this._previous;
    if (this._previous) return this._previous.getPreviousT(T);
  }
  get durationValue() {
    return this.duration || (this._previous ? this._previous.durationValue : Duration.default);
  }
  get durationMagnitude() {
    return this.durationValue.magnitude;
  }
  get division() {
    return this.durationValue.division;
  }
  get withMultiplier() {
    return this.duration && this.duration.withMultiplier;
  }
  get isMusic() {
    return true;
  }
  get isTying() {
    return this.post_events && this.post_events.some(event => event instanceof PostEvent && event.isTying);
  }
  get isStaccato() {
    return this.post_events && this.post_events.some(event => event instanceof PostEvent && event.isStaccato);
  }
  // to be implement in derived classes
  get isRest() {
    return null;
  }
  get beamOn() {
    return this.post_events && this.post_events.includes("[");
  }
  get beamOff() {
    return this.post_events && this.post_events.includes("]");
  }
  get measures() {
    if (!Number.isFinite(this._measure) || !Number.isFinite(this._lastMeasure)) return [];
    return Array(this._lastMeasure + 1 - this._measure).fill(null).map((_, i) => this._measure + i);
  }
  get measureLayout() {
    if (this.measures.length > 1) return measureLayout.BlockMLayout.fromSeq(this.measures.map(measure => measureLayout.SingleMLayout.from(measure)));
    if (this.measures.length === 1) return measureLayout.SingleMLayout.from(this._measure);
    return null;
  }
  get implicitType() {
    if (this.post_events) {
      for (const event of this.post_events) {
        if (event instanceof PostEvent && event.arg instanceof Command) {
          switch (event.arg.cmd) {
            case "startTrillSpan":
            case "trill":
              return ImplicitType.Trill;
            case "turn":
              return ImplicitType.Turn;
            case "mordent":
              return ImplicitType.Mordent;
            case "prall":
              return ImplicitType.Prall;
            // Arpeggio is not implemented in 'articulate.ly' yet
            case "arpeggio":
              return ImplicitType.Arpeggio;
          }
        }
      }
    }
    return ImplicitType.None;
  }
  get clarified() {
    const clarified = this instanceof Chord ? this.clarifiedChord : this.clone();
    clarified.duration = this.durationValue && this.durationValue.clone();
    return clarified;
  }
}
;
export class Chord extends MusicEvent {
  constructor(data) {
    super(data);
    this.connectPitches();
  }
  connectPitches() {
    if (this.basePitch) this.basePitch._parent = this;
    for (let i = 1; i < this.pitchElements.length; ++i) this.pitchElements[i]._previous = this.pitchElements[i - 1];
  }
  get single() {
    return this.pitches.length === 1;
  }
  get entries() {
    const list = [...this.pitches];
    if (Array.isArray(this.post_events)) list.push(...this.post_events);
    return list;
  }
  serialize() {
    const innerPitches = this.pitches.map(BaseTerm.optionalSerialize);
    const pitches = this.single && !this.options.withAngle ? cc(innerPitches) : ["<", "\b", ...cc(innerPitches), "\b", ">"];
    const {
      exclamations,
      questions,
      rest
    } = this.options;
    const postfix = cc([...(exclamations || []), ...(questions || []), ...BaseTerm.optionalSerialize(this.duration), rest].filter(item => item).map(item => ["\b", item])).concat(...(this.post_events || []).map(BaseTerm.optionalSerialize));
    return [new OpenLocator(this), ...pitches, ...postfix, new CloseLocator(this)];
  }
  get pitchElements() {
    return this.pitches.filter(pitch => pitch instanceof ChordElement);
  }
  get pitchNames() {
    return this.pitchElements.map(elem => elem.pitch.replace(/'|,/g, ""));
  }
  get basePitch() {
    return this.pitchElements[0];
  }
  get absolutePitch() {
    console.assert(!!this.basePitch, "absolutePitch on non pitch:", this.join());
    return this.basePitch.absolutePitch;
  }
  get anchorPitch() {
    if (this._anchorPitch) return this._anchorPitch;
    const previous = this.getPreviousT(Chord);
    if (previous) return previous.absolutePitch;
    return this.basePitch;
  }
  get isRest() {
    return !!this.options.rest;
  }
  get completeTied() {
    return this.pitchElements.filter(pitch => !pitch._tied).length === 0;
  }
  get pitchesValue() {
    if (this._previous instanceof Chord && this.basePitch.pitch === "q") {
      const pitches = this._previous.pitchesValue.map(pitch => {
        const newPitch = pitch.clone();
        if (newPitch instanceof ChordElement) {
          newPitch._location = this.basePitch._location;
          newPitch._tied = this.basePitch._tied;
          newPitch._parent = pitch._parent && this;
          newPitch._previous = pitch._previous;
        }
        return newPitch;
      });
      const base = pitches.find(pitch => pitch instanceof ChordElement);
      if (base) base.pitch = base.pitch.replace(/[,']/g, "");
      return pitches;
    }
    return this.pitches;
  }
  get clarifiedChord() {
    const clarified = this.clone();
    clarified.pitches = this.pitchesValue.filter(pitch => !pitch._tied).map(pitch => pitch.clone());
    clarified.connectPitches();
    // replace by rest if all pitches tied
    if (!clarified.pitches.length) return new Rest({
      name: "r",
      duration: this.duration
    });
    return clarified;
  }
  shiftAnchor(newAnchor) {
    //console.warn("shiftAnchor:", this.join(), newAnchor.join(), this.absolutePitch.pitchValue, newAnchor.pitchValue, this.anchorPitch.pitchValue);
    const _location = this.basePitch._location;
    const shift = idioms.phonetDifferToShift(this.basePitch.phonetStep - newAnchor.phonetStep);
    const relativeOctave = this.basePitch.absoluteOctave(this.anchorPitch) - newAnchor.octave - shift;
    //console.log("_location:", _location);
    this.pitches[0] = ChordElement.from({
      phonet: this.basePitch.phonet,
      alters: this.basePitch.alters,
      octave: relativeOctave
    });
    this.pitches[0]._location = _location;
    this.pitches[0]._parent = this;
    this.connectPitches();
    //console.log("shiftAnchor.1:", this.join(), this.absolutePitch.pitchValue, {relativeOctave, shift, "newAnchor.octave": newAnchor.octave});
  }
  makeRelativeTo(from) {
    const _location = this.basePitch._location;
    const octave = this.basePitch.relativeOctave(from);
    this.pitches[0] = ChordElement.from({
      phonet: this.basePitch.phonet,
      alters: this.basePitch.alters,
      octave
    });
    this.pitches[0]._location = _location;
    this.pitches[0]._parent = this;
  }
}
;
export class Rest extends MusicEvent {
  serialize() {
    return [new OpenLocator(this), ...compact([this.name, ...BaseTerm.optionalSerialize(this.duration)]), ...cc((this.post_events || []).map(BaseTerm.optionalSerialize)), new CloseLocator(this)];
  }
  get isSpacer() {
    return this.name === "s";
  }
  get isRest() {
    return true;
  }
}
;
export class ChordElement extends BaseTerm {
  constructor(data) {
    super(data);
    if (this.options.post_events) this.options.post_events = this.options.post_events.map(parseRaw);
    if (!this.pitch) console.log("null pitch:", this);
  }
  static from({
    phonet,
    alters = "",
    octave,
    options = {}
  }) {
    const octaveString = octave ? Array(Math.abs(octave)).fill(octave > 0 ? "'" : ",").join("") : "";
    const pitch = phonet + (alters || "") + octaveString;
    return new ChordElement({
      pitch,
      options: {
        ...options,
        proto: "_PLAIN"
      }
    });
  }
  static get default() {
    return ChordElement.from({
      phonet: "c",
      octave: 0
    });
  }
  serialize() {
    const {
      exclamations,
      questions,
      post_events
    } = this.options;
    const postfix = [].concat(...[...(exclamations || []), ...(questions || [])].filter(item => item).map(item => ["\b", item])).concat(...(post_events || []).map(item => ["\b", ...BaseTerm.optionalSerialize(item)]));
    return [new OpenLocator(this), this.pitch, ...postfix, new CloseLocator(this)];
  }
  get octave() {
    const positive = (this.pitch.match(/'/g) || []).length;
    const negative = (this.pitch.match(/,/g) || []).length;
    return positive - negative;
  }
  get phonet() {
    const ph = this.pitch.substr(0, 1);
    return idioms.PHONETS_ALIAS[ph] || ph;
  }
  get phonetStep() {
    return idioms.PHONETS.indexOf(this.phonet);
  }
  get alters() {
    const captures = this.pitch.substr(1).match(/^\w+/);
    return captures && captures[0];
  }
  get alteredPhonet() {
    const captures = this.pitch.match(/^\w+/);
    return captures && captures[0];
  }
  get anchorPitch() {
    if (this._previous) return this._previous.absolutePitch;
    if (this._parent) return this._parent.anchorPitch;
    return ChordElement.from({
      phonet: this.phonet,
      octave: 0
    });
  }
  getAbsolutePitch() {
    if (this.phonet === "q") return this.anchorPitch;
    if (this.anchorPitch === this) return this;
    const octave = this.absoluteOctave(this.anchorPitch);
    return ChordElement.from({
      phonet: this.phonet,
      alters: this.alters,
      octave
    });
  }
  get absolutePitch() {
    if (!this._absolutePitch) this._absolutePitch = this.getAbsolutePitch();
    return this._absolutePitch;
  }
  absoluteOctave(anchor) {
    if (this.phonet === "q") return anchor.octave;
    const phonetDiffer = this.phonetStep - anchor.phonetStep;
    const shift = idioms.phonetDifferToShift(phonetDiffer);
    return anchor.octave + shift + this.octave;
  }
  relativeOctave(from) {
    if (this.phonet === "q") {
      if (this.anchorPitch) return this.anchorPitch.relativeOctave(from);else return 0;
    }
    const phonetDiffer = this.phonetStep - from.phonetStep;
    const shift = idioms.phonetDifferToShift(phonetDiffer);
    return this.octave - shift - from.octave;
  }
  get alterValue() {
    return idioms.ALTER_VALUES[this.alters] || 0;
  }
  get pitchValue() {
    const phonetValue = idioms.PHONET_VALUES[this.phonet];
    console.assert(Number.isInteger(phonetValue), "invalid phonet:", this.phonet);
    console.assert(!this.alters || idioms.ALTER_VALUES[this.alters], "invalid alters:", this.alters);
    return 48 + this.octave * 12 + phonetValue + this.alterValue;
  }
  get absolutePitchValue() {
    return this.absolutePitch.pitchValue;
  }
  // middle C is zero
  get notePosition() {
    const phonet = idioms.PHONETS.indexOf(this.phonet);
    return (this.octave - 1) * 7 + phonet;
  }
  get absoluteNotePosition() {
    return this.absolutePitch.notePosition;
  }
  get tiedParent() {
    if (!this._tied || !(this._tied instanceof Chord)) return null;
    const pitch = this._tied.pitchElements.find(p => p.absolutePitchValue === this.absolutePitchValue);
    if (!pitch) return null;
    if (pitch._tied) return pitch.tiedParent;
    return pitch;
  }
}
;
export class Duration extends BaseTerm {
  static get default() {
    if (!Duration._default) Duration._default = new Duration({
      number: 4,
      dots: 0
    });
    return Duration._default;
  }
  static fromMagnitude(magnitude) {
    const MULTI = 1024;
    const MULTI_DURATION_MAGNITUDE = WHOLE_DURATION_MAGNITUDE * MULTI;
    const multiMag = magnitude * MULTI;
    if (!Number.isInteger(multiMag)) {
      console.warn("magnitude must be integer:", magnitude);
      return null;
    }
    const di = gcd(multiMag, MULTI_DURATION_MAGNITUDE);
    const denominator = MULTI_DURATION_MAGNITUDE / di;
    const numerator = multiMag / di;
    if (!Number.isInteger(Math.log2(denominator))) return new Duration({
      number: 1,
      dots: 0,
      multipliers: [`${numerator}/${denominator}`]
    });
    switch (numerator) {
      case 1:
        return new Duration({
          number: denominator,
          dots: 0
        });
      case 3:
        return new Duration({
          number: denominator / 2,
          dots: 1
        });
      case 7:
        return new Duration({
          number: denominator / 4,
          dots: 2
        });
      default:
        return new Duration({
          number: denominator,
          dots: 0,
          multipliers: [numerator.toString()]
        });
    }
  }
  serialize() {
    const dots = Array(this.dots).fill(".").join("");
    const multipliers = this.multipliers && this.multipliers.map(multiplier => `*${multiplier}`).join("");
    return compact([this.number, dots, multipliers]);
  }
  get withMultiplier() {
    return this.multipliers && this.multipliers.length > 0;
  }
  get denominator() {
    switch (this.number) {
      case "\\breve":
        return 0.5;
      case "\\longa":
        return 0.25;
    }
    return Number(this.number);
  }
  get division() {
    return Math.log2(this.denominator);
  }
  // how many smallest rhythm unit in a whole note
  get subdivider() {
    return this.denominator * 2 ** this.dots;
  }
  get magnitude() {
    let value = WHOLE_DURATION_MAGNITUDE / this.denominator;
    if (this.dots) value *= 2 - 0.5 ** this.dots;
    if (this.multipliers) this.multipliers.forEach(multiplier => value *= eval(multiplier));
    return value;
  }
}
;
;
export class BriefChord extends BaseTerm {
  constructor(data) {
    super(data);
    if (this.body) this.body.duration = parseRaw(this.body.duration);
  }
  serialize() {
    const {
      pitch,
      duration,
      separator,
      items
    } = this.body;
    return [...compact(cc([pitch, duration, separator, ...(items || [])].map(BaseTerm.optionalSerialize))), ...cc((this.post_events || []).map(BaseTerm.optionalSerialize))];
  }
  get isMusic() {
    return true;
  }
  get durationMagnitude() {
    if (this.body.duration) return this.body.duration.magnitude;
    return 0;
  }
}
;
export class NumberUnit extends BaseTerm {
  serialize() {
    return [this.number, "\b", this.unit];
  }
  set({
    number,
    unit
  }) {
    this.number = Number(number.toFixed(2));
    if (unit !== undefined) this.unit = unit;
  }
}
export class Tempo extends BaseTerm {
  static fromNoteBpm(note, bpm) {
    return new Tempo({
      unit: new Duration({
        number: note.toString(),
        dots: 0
      }),
      beatsPerMinute: bpm
    });
  }
  serialize() {
    const assignment = Number.isFinite(this.beatsPerMinute) ? [...BaseTerm.optionalSerialize(this.unit), "=", this.beatsPerMinute] : [];
    return ["\\tempo", ...BaseTerm.optionalSerialize(this.text), ...assignment];
  }
}
const DIRECTION_CHAR = {
  up: "^",
  down: "_",
  middle: "-"
};
export class PostEvent extends BaseTerm {
  serialize() {
    const dir = DIRECTION_CHAR[this.direction];
    const prefix = dir ? [dir, "\b"] : [];
    return prefix.concat(BaseTerm.optionalSerialize(this.arg));
  }
  get entries() {
    if (this.arg instanceof BaseTerm) return [this.arg];
    return null;
  }
  get isTying() {
    return this.arg === "~";
  }
  get isStaccato() {
    if (this.arg instanceof Command) return ["staccato", "staccatissimo", "portato"].includes(this.arg.cmd);
    if ([".", "!"].includes(this.arg)) return true;
    return false;
  }
}
;
export class Fingering extends BaseTerm {
  serialize() {
    return [this.value];
  }
}
;
export class Markup extends BaseTerm {
  serialize() {
    return [...cc(this.head.map(BaseTerm.optionalSerialize)), ...BaseTerm.optionalSerialize(this.body)];
  }
}
;
export class Lyric extends MusicEvent {
  serialize() {
    return [...BaseTerm.optionalSerialize(this.content), ...BaseTerm.optionalSerialize(this.duration), ...cc((this.post_events || []).map(BaseTerm.optionalSerialize))];
  }
}
;
export class Comment extends BaseTerm {
  serialize() {
    return [this.text, "\n"];
  }
  static createSingle(text) {
    return new Comment({
      text: "%" + text
    });
  }
  static createScoped(text) {
    console.assert(!/%\}/.test(text), "invalid scoped comment text:", text);
    return new Comment({
      text: `%{${text}%}`,
      scoped: true
    });
  }
}
;
export class Unexpect extends BaseTerm {
  constructor(data) {
    super(data);
    console.warn("unexpected term", data);
  }
}
;
export const termDictionary = {
  Root,
  LiteralString,
  Command,
  Variable,
  MarkupCommand,
  Repeat,
  Relative,
  ParallelMusic,
  TimeSignature,
  Partial,
  Times,
  Tuplet,
  Grace,
  AfterGrace,
  Clef,
  KeySignature,
  OctaveShift,
  Include,
  Version,
  Language,
  LyricMode,
  ChordMode,
  Transposition,
  StemDirection,
  Change,
  Block,
  InlineBlock,
  Scheme,
  SchemeFunction,
  SchemePair,
  SchemePointer,
  SchemeEmbed,
  Assignment,
  Duration,
  ChordElement,
  Chord,
  Rest,
  BriefChord,
  NumberUnit,
  MusicBlock,
  SimultaneousList,
  ContextedMusic,
  Divide,
  Tempo,
  PostEvent,
  Fingering,
  Markup,
  Lyric,
  Primitive,
  Comment
};
const termProtoMap = Object.entries(termDictionary).reduce((map, [name, cls]) => (map.set(cls.prototype, name), map), new Map());
const parseRawEnforce = data => {
  switch (typeof data) {
    case "string":
    case "number":
      return new Primitive({
        exp: data
      });
    default:
      return parseRaw(data);
  }
};
export const parseRaw = data => {
  if (data instanceof BaseTerm) return data;
  if (!data) return data;
  switch (typeof data) {
    case "object":
      if (Array.isArray(data)) return data.map(item => parseRaw(item));
      const {
        proto,
        ...fields
      } = data;
      if (proto) {
        if (proto === "_PLAIN") return fields;
        const termClass = termDictionary[proto];
        if (!termClass) throw new Error(`Unexpected term class: ${data.proto}`);
        return new termClass(fields);
      }
      return new Unexpect(data);
  }
  return data;
};"},{"version":3,"names":["WHOLE_DURATION_MAGNITUDE","FractionNumber","lcmMulti","gcd","MAIN_SCORE_NAME","idioms","LILYPOND_VERSION","measureLayout","ImplicitType","pick","Locator","constructor","term","_location","lines","columns","location","OpenLocator","set","line","column","CloseLocator","cc","arrays","concat","MusicChunk","parent","terms","join","chunks","map","chunk","i","length","Divide","push","size","durationMagnitude","reduce","magnitude","isNullItem","item","undefined","Array","isArray","compact","items","index","getDurationSubdivider","MusicEvent","Rest","isSpacer","durationValue","subdivider","MusicBlock","body","Times","Tuplet","divider","factor","reciprocal","numerator","music","reduced","Repeat","bodyBlock","Relative","isMusic","console","warn","constructMusicFromMeasureLayout","layout","joinMeasureSeq","seq","sublayout","SingleMLayout","get","measure","assert","BlockMLayout","VoltaMLayout","bodyTerms","alternative","alternates","alternate","repeat","createVolta","times","toString","ABAMLayout","mainList","main","restTerms","rest","block","Variable","name","BaseTerm","data","key","parseRaw","serialize","words","filter","word","includes","indent","result","pop","char","test","fill","relocate","source","replace","chars","split","wordIndex","Error","clone","JSON","parse","stringify","entries","musicChunks","entry","measures","indices","_measure","Number","isInteger","from","Set","proto","termProtoMap","Object","getPrototypeOf","href","getField","query","appendAssignment","value","assign","findFirst","condition","isPrototypeOf","termClass","findLast","reversedEntries","reverse","findAll","forEachTerm","handle","forEachTopTerm","toJSON","fields","keys","forEach","isTerm","x","optionalSerialize","_headComment","_tailComment","serializeScheme","Root","sections","section","getBlock","head","find","includeFiles","Include","include","filename","priorityForSection","Version","Language","Scheme","Assignment","Block","Infinity","reorderSections","sort","s1","s2","Primitive","exp","LiteralString","fromString","content","eval","err","Command","args","_parent","createSet","cmd","arg","some","isRepeatWithAlternative","Grace","getAssignmentPair","queryValue","dict","field","MarkupCommand","strs","type","alternativeBlocks","completeAlternativeBlocks","slice","list","sumDuration","Duration","fromMagnitude","events","m","event","singleTremolo","getUnfoldTerms","getPlainTerms","getTailPassTerms","makeBlock","anchor","chord","Chord","anchorPitch","ChordElement","headChord","tailPitch","tail","absolutePitch","shiftBody","newAnchor","shiftAnchor","_anchorPitch","ParallelMusic","varNames","asList","voices","voiceNames","measureCount","Math","ceil","_","Boolean","TimeSignature","fromExpression","Partial","duration","AfterGrace","grace","fromSeq","Clef","clefName","KeySignature","keyPitch","pitch","options","minor","phonetOrder","FIFTH_PHONETS","indexOf","phonet","alterValue","OctaveShift","create","default","version","make","language","LyricMode","ChordMode","Transposition","transposition","pitchValue","StemDirection","direction","substr","Change","parseRawEnforce","heads","isMIDIDedicated","subBlocks","assignmentDict","assignments","assignment","InlineBlock","fromTerms","clarifyHead","prototype","call","currentChunk","dumpChunk","header","SchemePointer","SchemeFunction","isRelative","subterms","subIndices","min","max","notes","isRest","sonicNotes","note","completeTied","noteTicks","ticks","_tick","t1","t2","measureTicks","tickTable","isFinite","tick","_functional","trimSeq","measureChunkMap","Map","clearPitchCache","_absolutePitch","updateChordAnchors","updateChordChains","previous","_previous","spreadRepeatBlocks","ignoreRepeat","keepTailPass","unfoldDurationMultipliers","timeDenominator","unfoldMultipliers","denominator","multipliers","multiplier","restCount","rests","floor","number","dots","expandVariables","clonedValue","redivide","recursive","measureHeads","nextHead","endTick","post_events","startTick","nextMeasure","_lastMeasure","sum","isPostTerm","PostEvent","newMeasures","has","comment","Comment","createSingle","add","firstEventIndex","firstEvent","clarified","splice","absoluteToRelative","newBody","newPitch","makeRelativeTo","SimultaneousList","removeStaffGroup","track","ContextedMusic","lyrics","withClause","contextDict","withEntries","pair","func","SchemePair","left","right","SchemeEmbed","values","getPreviousT","T","division","withMultiplier","isTying","isStaccato","beamOn","beamOff","implicitType","Trill","Turn","Mordent","Prall","Arpeggio","None","clarifiedChord","connectPitches","basePitch","pitchElements","single","pitches","innerPitches","withAngle","exclamations","questions","postfix","pitchNames","elem","_tied","pitchesValue","base","shift","phonetDifferToShift","phonetStep","relativeOctave","absoluteOctave","octave","alters","log","octaveString","abs","positive","match","negative","ph","PHONETS_ALIAS","PHONETS","captures","alteredPhonet","getAbsolutePitch","phonetDiffer","ALTER_VALUES","phonetValue","PHONET_VALUES","absolutePitchValue","notePosition","absoluteNotePosition","tiedParent","p","_default","MULTI","MULTI_DURATION_MAGNITUDE","multiMag","di","log2","BriefChord","separator","NumberUnit","unit","toFixed","Tempo","fromNoteBpm","bpm","beatsPerMinute","text","DIRECTION_CHAR","up","down","middle","dir","prefix","Fingering","Markup","Lyric","createScoped","scoped","Unexpect","termDictionary","cls"],"sources":["/home/camus/work/lotus/node_modules/eslint-loader/index.js??ref--14-0!/home/camus/work/lotus/inc/lilyParser/lilyTerms.ts"],"sourcesContent":["\nimport {WHOLE_DURATION_MAGNITUDE, FractionNumber, lcmMulti, gcd, MAIN_SCORE_NAME} from \"./utils\";\nimport * as idioms from \"./idioms\";\nimport {LILYPOND_VERSION} from \"../constants\";\nimport * as measureLayout from \"../measureLayout\";\nimport ImplicitType from \"../lilyNotation/implicitType\";\nimport pick from \"../pick\";\n\n\n\ninterface Location {\n\tlines: [number, number];\n\tcolumns: [number, number];\n};\n\n\nabstract class Locator {\n\tlocation: Location;\n\n\n\tconstructor (term: BaseTerm) {\n\t\tterm._location = term._location || {lines: [0, 0], columns: [0, 0]};\n\t\tthis.location = term._location;\n\t}\n\n\tabstract set (line: number, column: number): void;\n};\n\n\nclass OpenLocator extends Locator {\n\tset (line: number, column: number) {\n\t\tthis.location.lines[0] = line;\n\t\tthis.location.columns[0] = column;\n\t}\n};\n\n\nclass CloseLocator extends Locator {\n\tset (line: number, column: number) {\n\t\tthis.location.lines[1] = line;\n\t\tthis.location.columns[1] = column;\n\t}\n};\n\n\n// concat array of array\nconst cc = <T>(arrays: T[][]): T[] => [].concat(...arrays);\n\n\nexport class MusicChunk {\n\tparent: MusicBlock;\n\tterms: BaseTerm[];\n\n\n\tstatic join (chunks: MusicChunk[]): BaseTerm[] {\n\t\treturn cc(chunks.map((chunk, i) => i === chunks.length - 1 ? chunk.terms : [...chunk.terms, new Divide({})]));\n\t}\n\n\n\tconstructor (parent: MusicBlock, terms: BaseTerm[] = []) {\n\t\tthis.parent = parent;\n\t\tthis.terms = terms;\n\t}\n\n\n\tpush (term: BaseTerm) {\n\t\tthis.terms.push(term);\n\t}\n\n\n\tget size () {\n\t\treturn this.terms.length;\n\t}\n\n\n\tget durationMagnitude () {\n\t\treturn this.terms.reduce((magnitude, term) => magnitude + term.durationMagnitude, 0);\n\t}\n};\n\n\ninterface MusicVoice {\n\tname?: string;\n\tbody: MusicChunk[];\n};\n\n\ntype MusicChunkMap = Map<number, MusicChunk>;\n\n\nconst isNullItem = item => item === \"\" || item === undefined || item === null || (Array.isArray(item) && !item.length);\nconst compact = items => cc(items.map((item, index) => isNullItem(item) ? [] : [index > 0 ? \"\\b\" : null, item]));\n\n\nexport const getDurationSubdivider = (term: BaseTerm): number => {\n\tif (term instanceof MusicEvent) {\n\t\tif (!(term instanceof Rest) || !term.isSpacer)\n\t\t\treturn term.durationValue.subdivider;\n\t}\n\telse if (term instanceof MusicBlock)\n\t\treturn lcmMulti(...term.body.map(getDurationSubdivider));\n\telse if (term instanceof MusicChunk)\n\t\treturn lcmMulti(...term.terms.map(getDurationSubdivider));\n\telse if ((term instanceof Times) || (term instanceof Tuplet)) {\n\t\tconst divider = term instanceof Tuplet ? term.divider : term.factor.reciprocal;\n\t\tdivider.numerator *= getDurationSubdivider(term.music);\n\n\t\treturn divider.reduced.numerator;\n\t}\n\telse if (term instanceof Repeat)\n\t\treturn getDurationSubdivider(term.bodyBlock);\n\telse if (term instanceof Relative)\n\t\treturn getDurationSubdivider(term.music);\n\telse if (term.isMusic)\n\t\tconsole.warn(\"[getDurationSubdivider]\tunexpected music term:\", term);\n\n\treturn 1;\n};\n\n\nexport const constructMusicFromMeasureLayout = (layout: measureLayout.MeasureLayout, chunks: MusicChunkMap): MusicChunk => {\n\tconst joinMeasureSeq = (seq: measureLayout.MeasureSeq): BaseTerm[] => MusicChunk.join(seq.map(sublayout => constructMusicFromMeasureLayout(sublayout, chunks)));\n\n\tif (layout instanceof measureLayout.SingleMLayout) {\n\t\tconst chunk = chunks.get(layout.measure);\n\t\tconsole.assert(!!chunk, \"no chunk for measure:\", layout.measure);\n\n\t\treturn chunk;\n\t}\n\telse if (layout instanceof measureLayout.BlockMLayout) {\n\t\tconst terms = joinMeasureSeq(layout.seq);\n\n\t\treturn new MusicChunk(null, terms);\n\t}\n\telse if (layout instanceof measureLayout.VoltaMLayout) {\n\t\tconst bodyTerms = joinMeasureSeq(layout.body);\n\t\tconst alternative = layout.alternates && layout.alternates.map(alternate => new MusicBlock({body: joinMeasureSeq(alternate)}));\n\n\t\tconst repeat = Repeat.createVolta(layout.times.toString(), new MusicBlock({body: bodyTerms}), alternative);\n\n\t\treturn new MusicChunk(null, [repeat]);\n\t}\n\telse if (layout instanceof measureLayout.ABAMLayout) {\n\t\tconst mainList = constructMusicFromMeasureLayout(layout.main, chunks);\n\t\tconst main = mainList.terms.length === 1 ? mainList.terms[0] : new MusicBlock({body: mainList.terms});\n\t\tconst restTerms = joinMeasureSeq(layout.rest);\n\n\t\tconst block = new MusicBlock({body: [main, ...restTerms]});\n\n\t\treturn new MusicChunk(null, [new Variable({name: \"lotusRepeatABA\"}), block]);\n\t}\n};\n\n\nexport class BaseTerm {\n\t_location?: Location;\n\t_measure?: number;\n\t_tick?: number;\n\t_previous?: BaseTerm;\n\t_anchorPitch?: ChordElement;\n\t_parent?: BaseTerm;\n\n\t_headComment: Comment;\n\t_tailComment: Comment;\n\n\t// lotus extensional function modifier\n\t_functional: string;\n\n\n\tconstructor (data: object) {\n\t\t//Object.assign(this, data);\n\t\tfor (const key in data) \n\t\t\tthis[key] = parseRaw(data[key]);\n\t}\n\n\n\tserialize (): any[] {\n\t\tconsole.warn(\"unimplemented serilization:\", this);\n\t\treturn [];\n\t}\n\n\n\tjoin (): string {\n\t\tlet words = this.serialize().filter(word => [\"string\", \"number\"].includes(typeof word)).map(word => word.toString()) as string[];\n\t\twords = words.filter((word, i) => !(i && words[i - 1] === \"\\n\" && word === \"\\n\"));\n\n\t\tlet indent = 0;\n\t\tconst result: string[] = [];\n\n\t\tconst pop = char => {\n\t\t\tif (!char || result[result.length - 1] === char) {\n\t\t\t\tresult.pop();\n\t\t\t\treturn true;\n\t\t\t}\n\t\t};\n\n\t\tfor (const word of words) {\n\t\t\tswitch (word) {\n\t\t\tcase \"\\b\":\n\t\t\t\t// remove last space\n\t\t\t\tpop(\" \");\n\t\t\t\tcontinue;\n\n\t\t\tcase \"\\b\\n\":\n\t\t\t\t// remove last newline\n\t\t\t\twhile (pop(\"\\t\")) {}\n\t\t\t\tpop(\"\\n\");\n\t\t\t\tcontinue;\n\n\t\t\tcase \"\\n\":\n\t\t\t\t// no space at line tail\n\t\t\t\tpop(\" \");\n\t\t\t}\n\n\t\t\tif (/^(\\}|>>)/.test(word))\n\t\t\t\tpop(\"\\t\"); // remove the last tab\n\n\t\t\tresult.push(word);\n\n\t\t\tif (/\\n$/.test(word)) {\n\t\t\t\tif (/(\\{|<<)\\n$/.test(word))\n\t\t\t\t\t++indent;\n\t\t\t\telse if (/^(\\}|>>)/.test(word)) \n\t\t\t\t\t--indent;\n\n\t\t\t\tif (indent)\n\t\t\t\t\tresult.push(...Array(indent).fill(\"\\t\"));\n\t\t\t}\n\t\t\telse\n\t\t\t\tresult.push(\" \");\n\t\t}\n\n\t\treturn result.join(\"\");\n\t}\n\n\n\trelocate (source: string = this.join()) {\n\t\tconst words = this.serialize()\n\t\t\t.filter(word => word !== null && word !== undefined\n\t\t\t\t&& (typeof word !== \"string\" || (/\\S/.test(word) && !word.includes(\"\\b\"))))\n\t\t\t.map(word => typeof word === \"string\" ? word.replace(/\\n/g, \"\") : word);\n\n\t\tconst chars = source.split(\"\");\n\t\tlet line = 1;\n\t\tlet column = 0;\n\n\t\tlet wordIndex = 0;\n\n\t\tfor (let i = 0; i < chars.length; ++i) {\n\t\t\tif (wordIndex >= words.length)\n\t\t\t\tbreak;\n\n\t\t\tconst char = chars[i];\n\n\t\t\tswitch (char) {\n\t\t\tcase \"\\n\":\n\t\t\t\t++line;\n\t\t\t\tcolumn = 0;\n\n\t\t\t\tbreak;\n\t\t\tcase \" \":\n\t\t\tcase \"\\t\":\n\t\t\t\t++column;\n\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tlet word = words[wordIndex];\n\t\t\t\twhile (word instanceof Locator) {\n\t\t\t\t\tword.set(line, column);\n\n\t\t\t\t\t++wordIndex;\n\t\t\t\t\tword = words[wordIndex];\n\t\t\t\t}\n\n\t\t\t\tif (wordIndex >= words.length)\n\t\t\t\t\tbreak;\n\n\t\t\t\tword = word.toString();\n\t\t\t\tif (char === word[0]) {\n\t\t\t\t\ti += word.length - 1;\n\t\t\t\t\tcolumn += word.length;\n\t\t\t\t\t++wordIndex;\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\t//debugger;\n\t\t\t\t\tthrow new Error(`unexpected char in source: [${i}]'${char}', expect: ${word}`);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\n\tclone (): this {\n\t\treturn parseRaw(JSON.parse(JSON.stringify(this)));\n\t}\n\n\n\tget entries (): BaseTerm[] {\n\t\treturn null;\n\t}\n\n\n\tget isMusic (): boolean {\n\t\treturn false;\n\t}\n\n\n\tget musicChunks (): MusicChunk[] {\n\t\tif (!this.isMusic || !this.entries)\n\t\t\treturn [];\n\n\t\treturn [].concat(...this.entries.map(entry => entry.musicChunks));\n\t}\n\n\n\tget measures (): number[] {\n\t\tconst indices = [this._measure].concat(...(this.entries || []).map(entry => entry.measures)).filter(index => Number.isInteger(index));\n\n\t\treturn Array.from(new Set(indices));\n\t}\n\n\n\tget durationMagnitude (): number {\n\t\treturn 0;\n\t}\n\n\n\tget proto () {\n\t\treturn termProtoMap.get(Object.getPrototypeOf(this));\n\t}\n\n\n\tget href (): string {\n\t\tif (this._location)\n\t\t\treturn `${this._location.lines[0]}:${this._location.columns[0]}:${this._location.columns[1]}`;\n\n\t\treturn null;\n\t}\n\n\n\tget measureLayout (): measureLayout.MeasureLayout {\n\t\treturn null;\n\t}\n\n\n\tgetField (key): any {\n\t\tconsole.assert(!!this.entries, \"[BaseTerm.getField] term's entries is null:\", this);\n\n\t\tfor (const entry of this.entries) {\n\t\t\tconst result = entry.query(key);\n\t\t\tif (result)\n\t\t\t\treturn result;\n\t\t}\n\t}\n\n\n\tquery (key: string): any {\n\t\tvoid(key);\n\t\t//console.warn(\"term.query not implemented:\", this);\n\t}\n\n\n\tappendAssignment (key, value) {\n\t\tconsole.assert(!!this.entries, \"no entries on this term.\");\n\n\t\tconst assign = this.getField(key);\n\t\tif (assign)\n\t\t\tassign.value = value;\n\t\telse {\n\t\t\tthis.entries.push(parseRaw({\n\t\t\t\tproto: \"Assignment\",\n\t\t\t\tkey,\n\t\t\t\tvalue: value,\n\t\t\t}));\n\t\t}\n\t}\n\n\n\tfindFirst (condition: Function): BaseTerm {\n\t\tif (!this.entries)\n\t\t\treturn null;\n\n\t\tif (BaseTerm.isPrototypeOf(condition)) {\n\t\t\tconst termClass = condition;\n\t\t\tcondition = term => term instanceof termClass;\n\t\t}\n\t\n\t\tfor (const entry of this.entries) {\n\t\t\tif (condition(entry))\n\t\t\t\treturn entry;\n\t\n\t\t\tif (entry instanceof BaseTerm) {\n\t\t\t\tconst result = entry.findFirst(condition);\n\t\t\t\tif (result)\n\t\t\t\t\treturn result;\n\t\t\t}\n\t\t}\n\t}\n\n\n\tfindLast (condition: any): BaseTerm {\n\t\tif (!this.entries)\n\t\t\treturn null;\n\n\t\tif (BaseTerm.isPrototypeOf(condition)) {\n\t\t\tconst termClass = condition;\n\t\t\tcondition = term => term instanceof termClass;\n\t\t}\n\t\n\t\tconst reversedEntries = [...this.entries];\n\t\treversedEntries.reverse();\n\n\t\tfor (const entry of reversedEntries) {\n\t\t\tif (condition(entry))\n\t\t\t\treturn entry;\n\t\n\t\t\tif (entry instanceof BaseTerm) {\n\t\t\t\tconst result = entry.findLast(condition);\n\t\t\t\tif (result)\n\t\t\t\t\treturn result;\n\t\t\t}\n\t\t}\n\t}\n\n\n\tfindAll (condition: any): any[] {\n\t\tif (!this.entries)\n\t\t\treturn [];\n\n\t\tif (BaseTerm.isPrototypeOf(condition)) {\n\t\t\tconst termClass = condition;\n\t\t\tcondition = term => term instanceof termClass;\n\t\t}\n\n\t\tconst result = [];\n\n\t\tfor (const entry of this.entries) {\n\t\t\tif (condition(entry))\n\t\t\t\tresult.push(entry);\n\t\n\t\t\tif (entry instanceof BaseTerm)\n\t\t\t\tresult.push(...entry.findAll(condition));\n\t\t}\n\n\t\treturn result;\n\t}\n\n\n\tforEachTerm (termClass, handle) {\n\t\tif (!this.entries)\n\t\t\treturn;\n\n\t\tfor (const entry of this.entries) {\n\t\t\tif (entry instanceof termClass)\n\t\t\t\thandle(entry);\n\n\t\t\tif (entry instanceof BaseTerm)\n\t\t\t\tentry.forEachTerm(termClass, handle);\n\t\t}\n\t}\n\n\n\tforEachTopTerm (termClass, handle) {\n\t\tif (!this.entries)\n\t\t\treturn;\n\n\t\tfor (const entry of this.entries) {\n\t\t\tif (entry instanceof termClass)\n\t\t\t\thandle(entry);\n\t\t\telse if (entry instanceof BaseTerm)\n\t\t\t\tentry.forEachTopTerm(termClass, handle);\n\t\t}\n\t}\n\n\n\ttoJSON () {\n\t\t// exlude meta fields in JSON\n\t\tconst fields = Object.keys(this).filter(key => !/^_/.test(key));\n\t\tconst data = pick(this, fields);\n\n\t\tObject.entries(data).forEach(([key, value]) => {\n\t\t\tif (value && typeof value === \"object\" && !Array.isArray(value) && !(value instanceof BaseTerm))\n\t\t\t\tdata[key] = {proto: \"_PLAIN\", ...value};\n\t\t});\n\n\t\treturn {\n\t\t\tproto: this.proto,\n\t\t\t...data,\n\t\t};\n\t}\n\n\n\tstatic isTerm (x): boolean {\n\t\treturn typeof x === \"object\" && x instanceof BaseTerm;\n\t}\n\n\n\tstatic optionalSerialize (item: any): any[] {\n\t\t//return BaseTerm.isTerm(item) ? (item as BaseTerm).serialize() : (item === undefined ? [] : [item]);\n\t\tif (!BaseTerm.isTerm(item))\n\t\t\treturn item === undefined ? [] : [item];\n\n\t\treturn [\n\t\t\t...BaseTerm.optionalSerialize(item._headComment),\n\t\t\t...item.serialize(),\n\t\t\t...(item._tailComment ? [\"\\b\\n\", \"\\t\"] : []),\n\t\t\t...BaseTerm.optionalSerialize(item._tailComment),\n\t\t];\n\t}\n\n\n\tstatic serializeScheme (item: any): any[] {\n\t\tif (typeof item === \"boolean\")\n\t\t\titem = item ? \"#t\" : \"#f\";\n\n\t\treturn BaseTerm.optionalSerialize(item);\n\t}\n}\n\n\nexport class Root extends BaseTerm {\n\tsections: BaseTerm[];\n\n\n\tserialize () {\n\t\treturn cc(this.sections.map(section => [...BaseTerm.optionalSerialize(section), \"\\n\\n\"]));\n\t}\n\n\n\tget entries (): BaseTerm[] {\n\t\treturn this.sections;\n\t}\n\n\n\tgetBlock (head): Block {\n\t\treturn this.entries.find((entry: any) => entry.head === head || (entry.head === \"\\\\\" + head)) as Block;\n\t}\n\n\n\tget includeFiles (): string[] {\n\t\treturn this.sections.filter(section => section instanceof Include).map((include: Include) => include.filename);\n\t}\n\n\n\tstatic priorityForSection (term: BaseTerm): number {\n\t\tif (term instanceof Version)\n\t\t\treturn 0;\n\n\t\tif (term instanceof Language)\n\t\t\treturn 1;\n\n\t\tif (term instanceof Scheme)\n\t\t\treturn 3;\n\n\t\tif (term instanceof Assignment)\n\t\t\treturn 7;\n\n\t\tif (term instanceof Block) {\n\t\t\tswitch (term.head) {\n\t\t\tcase \"\\\\header\":\n\t\t\t\treturn 2;\n\n\t\t\tcase \"\\\\paper\":\n\t\t\t\treturn 4;\n\n\t\t\tcase \"\\\\layout\":\n\t\t\t\treturn 5;\n\n\t\t\tcase \"\\\\score\":\n\t\t\t\treturn 10;\n\t\t\t}\n\t\t}\n\n\t\treturn Infinity;\n\t}\n\n\n\treorderSections () {\n\t\tthis.sections.sort((s1, s2) => Root.priorityForSection(s1) - Root.priorityForSection(s2));\n\t}\n};\n\n\nexport class Primitive extends BaseTerm {\n\texp: string | number;\n\n\n\tserialize () {\n\t\treturn [this.exp];\n\t}\n};\n\n\nexport class LiteralString extends BaseTerm {\n\texp: string\n\n\n\tstatic fromString (content: string): LiteralString {\n\t\treturn new LiteralString({exp: JSON.stringify(content)});\n\t}\n\n\n\tserialize () {\n\t\treturn [this.exp];\n\t}\n\n\n\ttoString () {\n\t\ttry {\n\t\t\treturn eval(this.exp);\n\t\t}\n\t\tcatch (err) {\n\t\t\tconsole.warn(\"invalid lilypond string exp:\", this.exp);\n\t\t\treturn this.exp;\n\t\t}\n\t}\n};\n\n\nexport class Command extends BaseTerm {\n\tcmd: string;\n\targs: any[];\n\n\n\tstatic createSet (key: string|BaseTerm, value: BaseTerm): Command {\n\t\treturn new Command({cmd: \"set\", args: [new Assignment({key, value})]});\n\t}\n\n\n\tconstructor (data) {\n\t\tsuper(data);\n\n\t\tthis.args.forEach(term => {\n\t\t\tif (term instanceof MusicBlock || term instanceof Block)\n\t\t\t\tterm._parent = this;\n\t\t});\n\t}\n\n\n\tserialize () {\n\t\treturn [\n\t\t\t\"\\\\\" + this.cmd,\n\t\t\t...[].concat(...this.args.map(BaseTerm.optionalSerialize)),\n\t\t\t[\"break\", \"pageBreak\", \"overrideProperty\"].includes(this.cmd) ? \"\\n\" : null,\n\t\t];\n\t}\n\n\n\tget entries () {\n\t\treturn this.args.filter(arg => arg instanceof BaseTerm);\n\t}\n\n\n\tget isMusic (): boolean {\n\t\treturn this.args.some(arg => arg.isMusic);\n\t}\n\n\n\tget musicChunks (): MusicChunk[] {\n\t\tif (this.cmd === \"alternative\")\n\t\t\treturn [].concat(...this.args[0].body.map(term => term.musicChunks));\n\n\t\treturn [].concat(...this.entries.map(entry => entry.musicChunks));\n\t}\n\n\n\tget isRepeatWithAlternative () {\n\t\treturn this.cmd === \"repeat\"\n\t\t\t&& this.args[2] instanceof MusicBlock\n\t\t\t&& this.args[3]\n\t\t\t&& this.args[3].cmd === \"alternative\";\n\t}\n\n\n\tget durationMagnitude (): number {\n\t\tswitch (this.cmd) {\n\t\t// TODO: refine this in Times\n\t\tcase \"times\": {\n\t\t\tconst factor = eval(this.args[0]);\n\t\t\treturn this.args[1].durationMagnitude * factor;\n\t\t}\n\n\t\t// TODO: refine this in Tuplet\n\t\tcase \"tuplet\": {\n\t\t\tconst factor = 1 / eval(this.args[0]);\n\t\t\treturn this.args[this.args.length - 1].durationMagnitude * factor;\n\t\t}\n\n\t\tcase \"afterGrace\":\n\t\t\treturn this.args[0].durationMagnitude;\n\n\t\tdefault:\n\t\t\tif (this instanceof Grace)\n\t\t\t\treturn 0;\n\n\t\t\treturn this.args.filter(arg => arg instanceof BaseTerm).reduce((magnitude, term) => magnitude + term.durationMagnitude, 0);\n\t\t}\n\t}\n\n\n\tget measureLayout (): measureLayout.MeasureLayout {\n\t\tconst args = [...this.args].reverse();\n\t\tfor (const arg of args) {\n\t\t\tconst layout = arg instanceof BaseTerm && arg.measureLayout;\n\t\t\tif (layout)\n\t\t\t\treturn layout;\n\t\t}\n\n\t\treturn null;\n\t}\n\n\n\tgetAssignmentPair (): {key: any, value: any} {\n\t\tif (this.args[0] instanceof Assignment)\n\t\t\treturn {key: this.args[0].key, value: this.args[0].value};\n\n\t\tif (this.args[1] instanceof Assignment)\n\t\t\treturn {key: this.args[0], value: this.args[1].value};\n\n\t\tif (typeof this.args[0] === \"string\")\n\t\t\treturn {key: this.args[0], value: \"\"};\n\n\t\treturn null;\n\t}\n};\n\n\nexport class Variable extends Command {\n\tname: string\n\n\n\tconstructor ({name}) {\n\t\tsuper({cmd: name, args: []});\n\n\t\tthis.name = name;\n\t}\n\n\n\ttoJSON (): any {\n\t\treturn {\n\t\t\tproto: this.proto,\n\t\t\tname: this.name,\n\t\t};\n\t}\n\n\n\tqueryValue (dict: BaseTerm): any {\n\t\tconst field = dict.getField(this.name);\n\n\t\treturn field && field.value;\n\t}\n\n\n\tget isMusic (): boolean {\n\t\tif ([MAIN_SCORE_NAME].includes(this.name))\n\t\t\treturn true;\n\n\t\treturn false;\n\t}\n};\n\n\nexport class MarkupCommand extends Command {\n\ttoString () {\n\t\tconst strs = [];\n\t\tthis.forEachTerm(LiteralString, term => strs.push(term.toString()));\n\n\t\treturn strs.join(\"\\n\");\n\t}\n};\n\n\nexport class Repeat extends Command {\n\tstatic createVolta (times: string, body: MusicBlock, alternative?: MusicBlock[]): Repeat {\n\t\tconst args: any[] = [\n\t\t\t\"volta\",\n\t\t\ttimes,\n\t\t\tbody,\n\t\t];\n\n\t\tif (alternative) {\n\t\t\targs.push(new Command({\n\t\t\t\tcmd: \"alternative\",\n\t\t\t\targs: [new MusicBlock({body: alternative})],\n\t\t\t}));\n\t\t}\n\n\t\treturn new Repeat({cmd: \"repeat\", args});\n\t}\n\n\n\tget type (): string {\n\t\treturn this.args[0];\n\t}\n\n\n\tget times () {\n\t\treturn Number(this.args[1]);\n\t}\n\n\n\tget bodyBlock (): MusicBlock {\n\t\treturn this.args[2];\n\t}\n\n\n\tget alternativeBlocks (): MusicBlock[] {\n\t\treturn this.args[3] && this.args[3].args[0].body;\n\t}\n\n\n\t// this result length equal to times, if not null\n\tget completeAlternativeBlocks (): MusicBlock[] {\n\t\tif (!this.alternativeBlocks || !this.alternativeBlocks.length)\n\t\t\treturn null;\n\n\t\tif (this.alternativeBlocks.length >= this.times)\n\t\t\treturn this.alternativeBlocks.slice(0, this.times);\n\n\t\tconst list = [];\n\t\tfor (let i = 0; i < this.times - this.alternativeBlocks.length; ++ i)\n\t\t\tlist.push(this.alternativeBlocks[0]);\n\t\tlist.push(...this.alternativeBlocks);\n\n\t\treturn list;\n\t}\n\n\n\tget measureLayout (): measureLayout.MeasureLayout {\n\t\tswitch (this.type) {\n\t\tcase \"volta\": {\n\t\t\tconst layout = new measureLayout.VoltaMLayout();\n\t\t\tlayout.times = this.times;\n\t\t\tlayout.body = this.bodyBlock.measureLayout.seq;\n\t\t\tlayout.alternates = this.alternativeBlocks && this.alternativeBlocks.map(block => block.measureLayout.seq);\n\n\t\t\treturn layout;\n\t\t}\n\n\t\tcase \"tremolo\":\n\t\t\treturn this.bodyBlock.measureLayout;\n\n\t\tdefault:\n\t\t\tconsole.warn(\"unsupported repeat type:\", this.type);\n\t\t}\n\n\t\treturn null;\n\t}\n\n\n\t// for tremolo\n\tget sumDuration (): Duration {\n\t\tif (this.bodyBlock instanceof MusicEvent)\n\t\t\treturn Duration.fromMagnitude(this.args[2].durationMagnitude * this.times);\n\t\telse if (this.bodyBlock instanceof MusicBlock) {\n\t\t\tconst events = this.bodyBlock.body.filter(term => term instanceof MusicEvent);\n\t\t\tconst magnitude = events.reduce((m, event) => m + event.durationMagnitude, 0) * this.times;\n\n\t\t\treturn Duration.fromMagnitude(magnitude);\n\t\t}\n\n\t\treturn null;\n\t}\n\n\n\tget singleTremolo (): boolean {\n\t\tif (this.type === \"tremolo\") {\n\t\t\tif (this.bodyBlock instanceof MusicEvent)\n\t\t\t\treturn true;\n\n\t\t\tif (this.bodyBlock instanceof MusicBlock) {\n\t\t\t\tconst events = this.bodyBlock.body.filter(term => term instanceof MusicEvent);\n\t\t\t\treturn events.length === 1;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\n\t// \\repeat {body} \\alternative {{alter1} {alter2}}\t\t=> body alter1 body alter2\n\tgetUnfoldTerms (): BaseTerm[] {\n\t\tconst completeAlternativeBlocks = this.completeAlternativeBlocks;\n\n\t\tconst list = [];\n\t\tfor (let i = 0; i < this.times; ++i) {\n\t\t\tlist.push(...this.bodyBlock.clone().body);\n\n\t\t\tif (completeAlternativeBlocks)\n\t\t\t\tlist.push(...completeAlternativeBlocks[i].clone().body);\n\t\t}\n\n\t\treturn list;\n\t}\n\n\n\t// \\repeat {body} \\alternative {{alter1} {alter2}}\t\t=> body alter1 alter2\n\tgetPlainTerms (): BaseTerm[] {\n\t\tconst list = [...this.bodyBlock.clone().body];\n\n\t\tconst alternativeBlocks = this.alternativeBlocks;\n\t\tif (alternativeBlocks)\n\t\t\talternativeBlocks.forEach(block => list.push(...block.clone().body));\n\n\t\treturn list;\n\t}\n\n\n\t// \\repeat {body} \\alternative {{alter1} {alter2}}\t\t=> body alter2\n\tgetTailPassTerms (): BaseTerm[] {\n\t\tconst list = [...this.bodyBlock.clone().body];\n\n\t\tconst alternativeBlocks = this.alternativeBlocks;\n\t\tif (alternativeBlocks)\n\t\t\tlist.push(...alternativeBlocks[alternativeBlocks.length - 1].clone().body);\n\n\t\treturn list;\n\t}\n};\n\n\nexport class Relative extends Command {\n\tstatic makeBlock (block: MusicBlock, {anchor}: {anchor?: ChordElement} = {}): Relative {\n\t\tif (!anchor) {\n\t\t\tconst chord = block.findFirst(Chord) as Chord;\n\t\t\tanchor = chord && chord.anchorPitch;\n\t\t}\n\n\t\treturn new Relative({cmd: \"relative\", args: [anchor, block].filter(term => term)});\n\t}\n\n\n\tget anchor (): ChordElement {\n\t\tif (this.args[0] instanceof ChordElement)\n\t\t\treturn this.args[0];\n\n\t\treturn null;\n\t}\n\n\n\tget music (): BaseTerm {\n\t\treturn this.args[this.args.length - 1];\n\t}\n\n\n\tget headChord (): Chord {\n\t\treturn this.findFirst(Chord) as Chord;\n\t}\n\n\n\tget tailPitch (): ChordElement {\n\t\tconst tail = this.findLast(Chord) as Chord;\n\n\t\treturn tail && tail.absolutePitch;\n\t}\n\n\n\t// with side effect\n\tshiftBody (newAnchor?: ChordElement): BaseTerm[] {\n\t\tconst headChord = this.headChord;\n\t\tif (newAnchor && headChord) {\n\t\t\theadChord.shiftAnchor(newAnchor);\n\t\t\theadChord._anchorPitch = null;\n\t\t\t//console.log(\"shiftAnchor.post:\", headChord.join(), headChord);\n\t\t}\n\n\t\tconst music = this.music;\n\t\tif (music instanceof MusicBlock) {\n\t\t\t//music.clearPitchCache();\n\t\t\treturn music.body;\n\t\t}\n\n\t\treturn [music];\n\t}\n}\n\n\nexport class ParallelMusic extends Command {\n\tget varNames (): string[] {\n\t\treturn ((this.args[0].exp as SchemePointer).value as SchemeFunction).asList as string[];\n\t}\n\n\n\tget body (): MusicBlock {\n\t\treturn this.args[1];\n\t}\n\n\n\tget voices (): MusicVoice[] {\n\t\tconst voiceNames = this.varNames;\n\t\tconst chunks = this.body.musicChunks;\n\t\tconst measureCount = Math.ceil(chunks.length / voiceNames.length);\n\n\t\treturn voiceNames.map((name, index) => ({\n\t\t\tname: name.toString(),\n\t\t\tbody: Array(measureCount).fill(null).map((_, m) => chunks[m * voiceNames.length + index]).filter(Boolean),\n\t\t}));\n\t}\n};\n\n\nexport class TimeSignature extends Command {\n\tget value (): FractionNumber {\n\t\treturn FractionNumber.fromExpression(this.args[0]);\n\t}\n};\n\n\nexport class Partial extends Command {\n\tget duration (): Duration {\n\t\treturn this.args[0];\n\t}\n};\n\n\nexport class Times extends Command {\n\tget factor (): FractionNumber {\n\t\treturn FractionNumber.fromExpression(this.args[0]);\n\t}\n\n\n\tget music (): BaseTerm {\n\t\treturn this.args[this.args.length - 1];\n\t}\n};\n\n\nexport class Tuplet extends Command {\n\tget divider (): FractionNumber {\n\t\treturn FractionNumber.fromExpression(this.args[0]);\n\t}\n\n\n\tget music (): BaseTerm {\n\t\treturn this.args[this.args.length - 1];\n\t}\n};\n\n\nexport class Grace extends Command {\n\tget music (): BaseTerm {\n\t\treturn this.args[this.args.length - 1];\n\t}\n};\n\n\nexport class AfterGrace extends Command {\n\tget body (): BaseTerm {\n\t\treturn this.args[0];\n\t}\n\n\tget grace (): BaseTerm {\n\t\treturn this.args[1];\n\t}\n\n\n\tget measureLayout (): measureLayout.MeasureLayout {\n\t\treturn measureLayout.BlockMLayout.fromSeq([\n\t\t\tthis.body.measureLayout,\n\t\t\tthis.grace.measureLayout,\n\t\t]);\n\t}\n};\n\n\nexport class Clef extends Command {\n\tget clefName (): string {\n\t\treturn this.args[0].toString();\n\t}\n};\n\n\nexport class KeySignature extends Command {\n\tget keyPitch (): ChordElement {\n\t\treturn new ChordElement({pitch: this.args[0], options: {proto: \"_PLAIN\"}});\n\t}\n\n\n\tget key (): number {\n\t\tconst keyPitch = this.keyPitch;\n\t\tconst minor = this.args[1] === \"\\\\minor\";\n\t\tconst phonetOrder = idioms.FIFTH_PHONETS.indexOf(keyPitch.phonet);\n\n\t\treturn phonetOrder + (minor ? -4 : -1) + keyPitch.alterValue * 7;\n\t}\n};\n\n\nexport class OctaveShift extends Command {\n\tget value (): number {\n\t\treturn this.args[0].exp;\n\t}\n};\n\n\nexport class Include extends Command {\n\tstatic create (filename: string): Include {\n\t\treturn new Include({cmd: \"include\", args: [LiteralString.fromString(filename)]});\n\t}\n\n\n\tget filename (): string {\n\t\treturn this.args[0].toString();\n\t}\n};\n\n\nexport class Version extends Command {\n\tstatic get default (): Version {\n\t\treturn new Version({cmd: \"version\", args: [LiteralString.fromString(LILYPOND_VERSION)]});\n\t}\n\n\n\tget version (): string {\n\t\treturn this.args[0].toString();\n\t}\n};\n\n\nexport class Language extends Command {\n\tstatic make (language: string): Language {\n\t\treturn new Language({cmd: \"language\", args: [LiteralString.fromString(language)]});\n\t}\n\n\n\tget language (): string {\n\t\treturn this.args[0].toString();\n\t}\n};\n\n\nexport class LyricMode extends Command {\n\tget block (): MusicBlock {\n\t\treturn this.args[0];\n\t}\n};\n\n\nexport class ChordMode extends Command {\n\tget block (): MusicBlock {\n\t\treturn this.args[0];\n\t}\n};\n\n\nexport class Transposition extends Command {\n\tget transposition (): number {\n\t\treturn this.args[0].pitchValue - 60;\n\t}\n};\n\n\nexport class StemDirection extends Command {\n\tget direction (): string {\n\t\treturn this.cmd.substr(4);\n\t}\n};\n\n\nexport class Change extends Command {\n\tget key (): string {\n\t\treturn this.args[0].toString();\n\t}\n\n\n\tget value (): string {\n\t\treturn this.args[1].toString();\n\t}\n};\n\n\nexport class Block extends BaseTerm {\n\tblock: string;\n\thead: (string|string[]);\n\tbody: BaseTerm[];\n\n\n\tconstructor (data) {\n\t\tsuper(data);\n\n\t\tthis.body = this.body.map(parseRawEnforce);\n\t}\n\n\n\tserialize () {\n\t\tconst heads = Array.isArray(this.head) ? this.head : (this.head ? [this.head] : []);\n\n\t\treturn [\n\t\t\t...heads,\n\t\t\t\"{\\n\",\n\t\t\t...cc(this.body.map(section => [...BaseTerm.optionalSerialize(section), \"\\n\"])),\n\t\t\t\"}\\n\",\n\t\t];\n\t}\n\n\n\tget entries () {\n\t\treturn this.body;\n\t}\n\n\n\tget isMIDIDedicated () {\n\t\tconst subBlocks = this.body.filter(term => term instanceof Block) as Block[];\n\n\t\treturn subBlocks.some(term => term.head === \"\\\\midi\")\n\t\t\t&& !subBlocks.some(term => term.head === \"\\\\layout\");\n\t}\n\n\n\tget assignmentDict (): {[key: string]: string} {\n\t\tconst assignments = this.body.filter(term => term instanceof Assignment) as Assignment[];\n\n\t\treturn assignments.reduce((dict, assignment) => ((dict[assignment.key.toString()] = assignment.value.toString()), dict), {});\n\t}\n};\n\n\nexport class InlineBlock extends Block {\n\tserialize () {\n\t\treturn [\n\t\t\t\"{\",\n\t\t\t...cc(this.body.map(BaseTerm.optionalSerialize)),\n\t\t\t\"}\",\n\t\t];\n\t}\n};\n\n\nexport class MusicBlock extends BaseTerm {\n\tbody: BaseTerm[];\n\n\n\tstatic fromTerms (terms: BaseTerm[]): MusicBlock {\n\t\tconst block = new MusicBlock({body: [...terms]});\n\t\tblock.clarifyHead();\n\n\t\treturn block;\n\t}\n\n\n\tconstructor (data) {\n\t\tsuper(data);\n\n\t\tthis.body = this.body.map(parseRawEnforce);\n\t}\n\n\n\tserialize () {\n\t\treturn [\n\t\t\t\"{\\n\",\n\t\t\t...cc(this.body.map(BaseTerm.optionalSerialize)),\n\t\t\t\"\\n\",\n\t\t\t\"}\\n\",\n\t\t];\n\t}\n\n\n\tclone (): this {\n\t\tif (this._parent) {\n\t\t\tconst parent = this._parent.clone();\n\t\t\tconst block = parent.findFirst(MusicBlock);\n\t\t\tconsole.assert(block && block._parent === parent, \"invalid block-parent relation\", parent, block);\n\n\t\t\treturn block as this;\n\t\t}\n\n\t\treturn BaseTerm.prototype.clone.call(this) as this;\n\t}\n\n\n\tget entries () {\n\t\treturn this.body;\n\t}\n\n\n\tget isMusic (): boolean {\n\t\treturn true;\n\t}\n\n\n\tget musicChunks (): MusicChunk[] {\n\t\tconst chunks = [];\n\t\tlet currentChunk = new MusicChunk(this);\n\n\t\tconst dumpChunk = () => {\n\t\t\tif (currentChunk.size)\n\t\t\t\tchunks.push(currentChunk);\n\n\t\t\tcurrentChunk = new MusicChunk(this);\n\t\t};\n\n\t\tfor (const term of this.entries) {\n\t\t\tif (term instanceof Repeat) {\n\t\t\t\tdumpChunk();\n\t\t\t\tchunks.push(...term.musicChunks);\n\t\t\t}\n\t\t\telse if (term instanceof Divide)\n\t\t\t\tdumpChunk();\n\t\t\telse\n\t\t\t\tcurrentChunk.push(term);\n\t\t}\n\n\t\tdumpChunk();\n\n\t\treturn chunks;\n\t}\n\n\n\t// [deprecated]\n\t// for parallelMusic only\n\tget voiceNames () {\n\t\tconst header = this._parent as Command;\n\t\tif (header && header.cmd === \"parallelMusic\") {\n\t\t\tif (header.args[0] instanceof Scheme && header.args[0].exp instanceof SchemePointer && header.args[0].exp.value instanceof SchemeFunction) {\n\t\t\t\tconst voices = header.args[0].exp.value.asList;\n\t\t\t\treturn voices;\n\t\t\t}\n\t\t}\n\n\t\treturn null;\n\t}\n\n\n\t// [deprecated]\n\tget voices (): MusicVoice[] {\n\t\tconst voiceNames = this.voiceNames;\n\t\tif (!voiceNames)\n\t\t\treturn [{body: this.musicChunks}];\n\n\t\tconst chunks = this.musicChunks;\n\t\tconst measureCount = Math.ceil(chunks.length / voiceNames.length);\n\n\t\treturn voiceNames.map((name, index) => ({\n\t\t\tname: name.toString(),\n\t\t\tbody: Array(measureCount).fill(null).map((_, m) => chunks[m * voiceNames.length + index]).filter(chunk => chunk),\n\t\t}));\n\t}\n\n\n\tget durationMagnitude (): number {\n\t\treturn this.body.reduce((magnitude, term) => magnitude + term.durationMagnitude, 0);\n\t}\n\n\n\tget isRelative (): boolean {\n\t\treturn this._parent instanceof Relative;\n\t}\n\n\n\tget anchorPitch (): ChordElement {\n\t\tif (this.isRelative) \n\t\t\treturn (this._parent as Relative).anchor;\n\n\t\treturn null;\n\t}\n\n\n\tget measures (): number[] {\n\t\t// make a continouse indices list\n\t\tconst subterms = this.findAll(term => term.isMusic);\n\t\tconst subIndices = [].concat(...subterms.map(term => term.measures)).filter(index => Number.isInteger(index));\n\t\tif (!subIndices.length)\n\t\t\treturn [];\n\n\t\tconst min = Math.min(...subIndices);\n\t\tconst max = Math.max(...subIndices);\n\n\t\treturn Array(max + 1 - min).fill(null).map((_, i) => i + min);\n\t}\n\n\n\tget notes (): Chord[] {\n\t\tconst notes = this.body.filter(term => term instanceof Chord && !term.isRest) as Chord[];\n\t\tthis.forEachTopTerm(MusicBlock, block => notes.push(...block.notes));\n\n\t\treturn notes;\n\t}\n\n\n\tget sonicNotes (): Chord[] {\n\t\treturn this.notes.filter(note => !note.completeTied);\n\t}\n\n\n\tget noteTicks (): number[] {\n\t\tconst ticks = this.sonicNotes.map(note => note._tick);\n\t\treturn Array.from(new Set(ticks)).sort((t1, t2) => t1 - t2);\n\t}\n\n\n\tget measureTicks (): [number, number][] {\n\t\tconst tickTable: {[key: string]: number} = {};\n\n\t\tthis.body.forEach(term => {\n\t\t\tif (Number.isFinite(term._measure) && Number.isFinite(term._tick)) {\n\t\t\t\tif (!Number.isFinite(tickTable[term._measure]))\n\t\t\t\t\ttickTable[term._measure] = term._tick;\n\t\t\t}\n\t\t});\n\n\t\treturn Object.entries(tickTable).map(([measure, tick]) => [Number(measure), tick]);\n\t}\n\n\n\tget measureLayout (): measureLayout.MeasureLayout {\n\t\tconst seq = this.body.filter(term => term.isMusic).map(term => term.measureLayout).filter(Boolean);\n\n\t\tif (this._functional === \"lotusRepeatABA\") {\n\t\t\tconst [main, ...rest] = seq;\n\n\t\t\tconst layout = new measureLayout.ABAMLayout();\n\t\t\tlayout.main = main;\n\t\t\tlayout.rest = measureLayout.BlockMLayout.trimSeq(rest);\n\n\t\t\treturn layout;\n\t\t}\n\n\t\treturn measureLayout.BlockMLayout.fromSeq(seq);\n\t}\n\n\n\tget measureChunkMap (): MusicChunkMap {\n\t\tconst map = new Map<number, MusicChunk>();\n\t\tthis.body.forEach(term => {\n\t\t\tif (Number.isInteger(term._measure) && !(term instanceof Divide)) {\n\t\t\t\tif (!map.get(term._measure))\n\t\t\t\t\tmap.set(term._measure, new MusicChunk(this));\n\n\t\t\t\tconst chunk = map.get(term._measure);\n\t\t\t\tchunk.terms.push(term);\n\t\t\t}\n\t\t});\n\n\t\treturn map;\n\t}\n\n\n\tclearPitchCache () {\n\t\tthis.forEachTerm(ChordElement, pitch => {\n\t\t\tpitch._absolutePitch = null;\n\t\t\t//pitch._previous = null;\n\t\t});\n\t}\n\n\n\tupdateChordAnchors () {\n\t\tconst chord = this.findFirst(Chord) as Chord;\n\t\tif (chord)\n\t\t\tchord._anchorPitch = chord._anchorPitch || this.anchorPitch;\n\n\t\tthis.clearPitchCache();\n\t}\n\n\n\t// deprecated\n\tupdateChordChains () {\n\t\tlet previous: MusicEvent = null;\n\n\t\tthis.updateChordAnchors();\n\n\t\tthis.forEachTerm(MusicBlock, block => block.updateChordAnchors());\n\n\t\tthis.forEachTerm(MusicEvent, event => {\n\t\t\tevent._previous = previous;\n\n\t\t\tprevious = event;\n\t\t});\n\t}\n\n\n\t// with side effect\n\tspreadRepeatBlocks ({ignoreRepeat = true, keepTailPass = false} = {}): this {\n\t\tthis.forEachTerm(MusicBlock, block => block.spreadRepeatBlocks());\n\n\t\tthis.body = cc(this.body.map(term => {\n\t\t\tif (term instanceof Repeat) {\n\t\t\t\tif (!ignoreRepeat)\n\t\t\t\t\treturn term.getUnfoldTerms();\n\t\t\t\telse if (keepTailPass)\n\t\t\t\t\treturn term.getTailPassTerms();\n\t\t\t\telse\n\t\t\t\t\treturn term.getPlainTerms();\n\t\t\t}\n\t\t\telse\n\t\t\t\treturn [term];\n\t\t}));\n\n\t\treturn this;\n\t}\n\n\n\t/*// with side effect\n\tspreadRelativeBlocks (): this {\n\t\tthis.forEachTerm(MusicBlock, block => block.spreadRelativeBlocks());\n\n\t\tlet anchorPitch = null;\n\n\t\tthis.body = cc(this.body.map(term => {\n\t\t\tif (term instanceof Relative) {\n\t\t\t\tconst list = term.shiftBody(anchorPitch);\n\n\t\t\t\tanchorPitch = term.tailPitch || anchorPitch;\n\n\t\t\t\treturn list;\n\t\t\t}\n\t\t\telse\n\t\t\t\treturn [term];\n\t\t}));\n\n\t\treturn this;\n\t}*/\n\n\n\t// with side effect\n\tunfoldDurationMultipliers (): this {\n\t\tlet timeDenominator = 4;\n\n\t\tconst unfoldMultipliers = (term): BaseTerm[] => {\n\t\t\tif (term instanceof TimeSignature)\n\t\t\t\ttimeDenominator = term.value.denominator;\n\n\t\t\tif (!(term instanceof MusicEvent) || !term.duration || !term.duration.multipliers || !term.duration.multipliers.length)\n\t\t\t\treturn [term];\n\n\t\t\tconst factor = term.duration.multipliers.reduce((factor, multiplier) => factor * Number(multiplier), 1);\n\t\t\tif (!Number.isInteger(factor) || factor <= 0)\n\t\t\t\treturn [term];\n\n\t\t\tconst denominator = Math.max(term.duration.denominator, timeDenominator);\n\n\t\t\tconst event = term.clone() as MusicEvent;\n\t\t\tevent.duration.multipliers = [];\n\n\t\t\t// break duration into multiple rest events\n\t\t\tconst restCount = (event.duration.magnitude / WHOLE_DURATION_MAGNITUDE) * (factor - 1) * denominator;\n\t\t\tif (!Number.isInteger(restCount))\n\t\t\t\tconsole.warn(\"Rest count is not integear:\", restCount, denominator, event.duration.magnitude, factor);\n\n\t\t\tconst rests = Array(Math.floor(restCount)).fill(null).map(() => \n\t\t\t\tnew Rest({name: \"s\", duration: new Duration({number: denominator, dots: 0})}));\n\n\t\t\treturn [event, ...rests];\n\t\t};\n\n\t\tthis.body = cc(this.body.map(unfoldMultipliers));\n\n\t\treturn this;\n\t}\n\n\n\t/*// pure\n\tflatten ({spreadRepeats = false} = {}): Relative {\n\t\tthis.updateChordChains();\n\n\t\tconst chord = this.findFirst(Chord) as Chord;\n\t\tconst anchor = this.anchorPitch || (chord && chord.anchorPitch);\n\n\t\tconst block = this.clone();\n\t\tif (spreadRepeats)\n\t\t\tblock.spreadRepeatBlocks();\n\t\tblock.spreadRelativeBlocks();\n\t\tblock.unfoldDurationMultipliers();\n\n\t\treturn Relative.makeBlock(block, {anchor: anchor && anchor.clone()});\n\t}*/\n\n\n\t// with side effect\n\texpandVariables (dict: BaseTerm): this {\n\t\tthis.body = this.body.map(term => {\n\t\t\tif (term instanceof Variable) {\n\t\t\t\tconst value = term.queryValue(dict);\n\t\t\t\tconst clonedValue = value instanceof BaseTerm ? value.clone() : value;\n\n\t\t\t\tif (clonedValue instanceof BaseTerm) {\n\t\t\t\t\tclonedValue.forEachTerm(MusicBlock, block => block.expandVariables(dict));\n\n\t\t\t\t\tif (clonedValue instanceof MusicBlock)\n\t\t\t\t\t\tclonedValue.expandVariables(dict);\n\t\t\t\t}\n\n\t\t\t\treturn clonedValue;\n\t\t\t}\n\n\t\t\treturn term;\n\t\t});\n\n\t\treturn this;\n\t}\n\n\n\t// with side effects\n\tredivide ({recursive = true, measureHeads = null}: {recursive?: boolean, measureHeads?: number[]} = {}) {\n\t\tif (recursive) {\n\t\t\tthis.forEachTerm(MusicBlock, block => {\n\t\t\t\tif (!block._parent || block._parent.cmd !== \"alternative\")\n\t\t\t\t\tblock.redivide({recursive, measureHeads});\n\t\t\t});\n\t\t}\n\n\t\t// split rests\n\t\tif (measureHeads) {\n\t\t\tthis.body = [].concat(...this.body.map(term => {\n\t\t\t\tif (!(term instanceof Rest) || term.name !== \"s\" || !Number.isInteger(term._measure))\n\t\t\t\t\treturn [term];\n\n\t\t\t\tconst nextHead = measureHeads[term._measure];\n\t\t\t\tconst endTick = term._tick + term.durationMagnitude;\n\t\t\t\tif (nextHead > 0 && endTick > nextHead) {\n\t\t\t\t\tconst post_events = term.post_events;\n\n\t\t\t\t\tlet startTick = term._tick;\n\t\t\t\t\tconst rests = [];\n\t\t\t\t\tlet nextMeasure;\n\t\t\t\t\tfor (nextMeasure = term._measure; nextMeasure < measureHeads.length && endTick > measureHeads[nextMeasure]; ++nextMeasure) {\n\t\t\t\t\t\tconst duration = Duration.fromMagnitude(measureHeads[nextMeasure] - startTick);\n\t\t\t\t\t\tif (!duration) {\n\t\t\t\t\t\t\tconsole.warn(\"invalid middle rest duration, splitting gave up:\", measureHeads[nextMeasure] - startTick, term);\n\t\t\t\t\t\t\treturn [term];\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\tconst rest = new Rest({name: \"s\", duration, post_events: []});\n\t\t\t\t\t\trest._measure = nextMeasure;\n\t\t\t\t\t\trest._lastMeasure = nextMeasure;\n\t\t\t\t\t\trests.push(rest);\n\n\t\t\t\t\t\tconsole.assert(!!rest.duration, \"middle splitted rest duration invalid:\", measureHeads[nextMeasure] - startTick);\n\n\t\t\t\t\t\tstartTick = measureHeads[nextMeasure];\n\t\t\t\t\t}\n\n\t\t\t\t\tconst duration = Duration.fromMagnitude(endTick - startTick);\n\t\t\t\t\tif (!duration) {\n\t\t\t\t\t\tconsole.warn(\"invalid tail rest duration, splitting gave up:\", endTick - startTick, term);\n\t\t\t\t\t\treturn [term];\n\t\t\t\t\t}\n\n\t\t\t\t\tconst rest = new Rest({name: \"s\", duration, post_events: post_events && [...post_events]});\n\t\t\t\t\trest._measure = nextMeasure;\n\t\t\t\t\trest._lastMeasure = nextMeasure;\n\t\t\t\t\trests.push(rest);\n\n\t\t\t\t\tconsole.assert(rests.reduce((sum, rest) => sum + rest.durationMagnitude, 0) === term.durationMagnitude, \"duration splitting error:\", rests, term);\n\t\t\t\t\t//if (rests.reduce((sum, rest) => sum + rest.durationMagnitude, 0) !== term.durationMagnitude)\n\t\t\t\t\t//\tdebugger;\n\n\t\t\t\t\treturn rests;\n\t\t\t\t}\n\n\t\t\t\treturn [term];\n\t\t\t}));\n\t\t}\n\n\t\tconst isPostTerm = term => !term\n\t\t\t|| term instanceof PostEvent\n\t\t\t|| (term as Primitive).exp === \"~\"\n\t\t\t|| [\"bar\", \"arpeggio\", \"glissando\", \"sustainOff\", \"sustainOn\"].includes((term as Command).cmd)\n\t\t\t;\n\n\t\tconst list = this.body.filter(term => !(term instanceof Divide));\n\t\tlet measure = null;\n\t\tfor (const term of list) {\n\t\t\tif (Number.isInteger(measure) && isPostTerm(term))\n\t\t\t\tterm._measure = measure;\n\t\t\telse\n\t\t\t\tmeasure = term._measure;\n\t\t}\n\n\t\tconst body: BaseTerm[] = [];\n\t\tconst measures = new Set();\n\n\t\tlist.reverse().forEach(term => {\n\t\t\tif (term instanceof BaseTerm) {\n\t\t\t\tconst newMeasures = term.measures.filter(m => !measures.has(m));\n\t\t\t\tif (newMeasures.length) {\n\t\t\t\t\tconst comment = \" \" + newMeasures[0] + (newMeasures.length > 1 ? \"-\" + Math.max(...newMeasures) : \"\");\n\n\t\t\t\t\tif (body.length)\n\t\t\t\t\t\tbody.push(new Divide({_tailComment: Comment.createSingle(comment)}));\n\n\t\t\t\t\tnewMeasures.forEach(m => measures.add(m));\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tbody.push(term);\n\t\t});\n\n\t\tthis.body = body.reverse();\n\t}\n\n\n\tclarifyHead () {\n\t\tconst terms = this.body;\n\n\t\tconst head = terms.find(term => term.isMusic);\n\t\tif (head instanceof MusicEvent) {\n\t\t\t// clarify the first music event content\n\t\t\tconst firstEventIndex = terms.indexOf(head);\n\t\t\tif (firstEventIndex >= 0) {\n\t\t\t\tconst firstEvent = terms[firstEventIndex] as MusicEvent;\n\t\t\t\t//console.log(\"firstEvent:\", firstEvent);\n\t\t\t\tif (firstEvent._previous) {\n\t\t\t\t\tconst clarified = firstEvent.clarified;\n\t\n\t\t\t\t\tterms.splice(firstEventIndex, 1, clarified);\n\t\t\t\t\t//console.log(\"terms:\", firstEventIndex, terms, clarified);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse if (head) {\n\t\t\tconst block = head.findFirst(MusicBlock) as MusicBlock;\n\t\t\tif (block)\n\t\t\t\tblock.clarifyHead();\n\t\t\telse\n\t\t\t\tconsole.warn(\"[MusicBlock.clarifyHead] unexpected music head:\", head);\n\t\t}\n\t}\n\n\n\tabsoluteToRelative (): Relative {\n\t\tconst anchor = this.findFirst(Chord) as Chord;\n\t\tif (!anchor)\n\t\t\treturn null;\n\n\t\tconst anchorPitch = anchor.absolutePitch;\n\t\tlet pitch = anchorPitch;\n\n\t\tconst newBody = this.clone();\n\t\tnewBody.forEachTerm(Chord, chord => {\n\t\t\tconst newPitch = chord.absolutePitch;\n\t\t\tchord.makeRelativeTo(pitch);\n\n\t\t\tpitch = newPitch;\n\t\t});\n\n\t\treturn Relative.makeBlock(newBody, {anchor: anchorPitch});\n\t}\n};\n\n\nexport class SimultaneousList extends BaseTerm {\n\tlist: BaseTerm[];\n\n\n\tserialize () {\n\t\treturn [\n\t\t\t\"<<\\n\",\n\t\t\t...cc(this.list.map(item => [...BaseTerm.optionalSerialize(item), \"\\n\"])),\n\t\t\t\">>\\n\",\n\t\t];\n\t}\n\n\n\tremoveStaffGroup () {\n\t\tfor (let i = 0; i < this.list.length; ++i) {\n\t\t\tconst item: any = this.list[i];\n\t\t\tif (item.head instanceof Command && item.head.args && item.head.args[0] === \"StaffGroup\")\n\t\t\t\tthis.list[i] = item.body;\n\t\t}\n\n\t\tthis.list.forEach(item => {\n\t\t\tif (item instanceof SimultaneousList)\n\t\t\t\titem.removeStaffGroup();\n\t\t});\n\t}\n\n\n\tget isMusic (): boolean {\n\t\treturn true;\n\t}\n\n\n\tget entries () {\n\t\treturn this.list;\n\t}\n\n\n\tget durationMagnitude (): number {\n\t\treturn Math.max(...this.list.filter(term => term instanceof BaseTerm).map(term => term.durationMagnitude));\n\t}\n\n\n\tget measureLayout (): measureLayout.MeasureLayout {\n\t\tconst track = this.list.find(term => term instanceof BaseTerm && term.measureLayout);\n\t\treturn track && track.measureLayout;\n\t}\n};\n\n\nexport class ContextedMusic extends BaseTerm {\n\thead: Command;\n\tbody: BaseTerm;\n\tlyrics?: BaseTerm;\n\n\n\tserialize () {\n\t\treturn [\n\t\t\t...BaseTerm.optionalSerialize(this.head),\n\t\t\t...BaseTerm.optionalSerialize(this.body),\n\t\t\t...BaseTerm.optionalSerialize(this.lyrics),\n\t\t];\n\t}\n\n\n\tget isMusic (): boolean {\n\t\treturn true;\n\t}\n\n\n\tget entries () {\n\t\treturn [this.head, this.body];\n\t}\n\n\n\tget type (): string {\n\t\treturn this.head.args[0];\n\t}\n\n\n\tget durationMagnitude (): number {\n\t\treturn this.body.durationMagnitude;\n\t}\n\n\n\tget withClause (): Command {\n\t\tif (this.head.args[2] && this.head.args[2] instanceof Command && this.head.args[2].cmd === \"with\")\n\t\t\treturn this.head.args[2];\n\t}\n\n\n\tget contextDict (): {[key: string]: string} {\n\t\tconst withEntries = this.withClause ? Object.entries((this.withClause.args[0] as Block).assignmentDict) : [];\n\t\tconst entries = withEntries.map(([key, value]) => [`${this.type}.${key}`, value]);\n\n\t\tconst pair = this.head.getAssignmentPair();\n\t\tif (pair)\n\t\t\tentries.push([pair.key.toString(), pair.value.toString()]);\n\n\t\treturn entries.reduce((dict, [key, value]) => ((dict[key] = value), dict), {});\n\t}\n\n\n\tget list (): BaseTerm[] {\n\t\tif (this.body instanceof SimultaneousList)\n\t\t\treturn this.body.list;\n\n\t\treturn null;\n\t}\n\n\n\tset list (value: BaseTerm[]) {\n\t\tif (this.body instanceof SimultaneousList)\n\t\t\tthis.body.list = value;\n\t}\n\n\n\tget measureLayout (): measureLayout.MeasureLayout {\n\t\treturn this.body.measureLayout;\n\t}\n};\n\n\nexport class Divide extends BaseTerm {\n\tserialize () {\n\t\treturn [\"|\", \"\\n\"];\n\t}\n}\n\n\nexport class Scheme extends BaseTerm {\n\texp: (boolean|BaseTerm);\n\n\n\tserialize () {\n\t\tif (BaseTerm.isTerm(this.exp))\n\t\t\treturn [\"#\", \"\\b\", ...(this.exp as BaseTerm).serialize()];\n\t\telse if (typeof this.exp === \"boolean\")\n\t\t\treturn [\"#\", \"\\b\", this.exp ? \"#t\" : \"#f\"];\n\t\t// TODO: enhance grammar to parse empty scheme list\n\t\t//else if (this.exp === null)\n\t\t//\treturn [\"#\", \"\\b\", \"'()\"];\n\t\telse\n\t\t\treturn [\"#\", \"\\b\", this.exp];\n\t}\n\n\n\tquery (key: string): any {\n\t\tif (this.exp instanceof SchemeFunction)\n\t\t\treturn this.exp.query(key);\n\t}\n\n\n\tget entries () {\n\t\tif (this.exp instanceof BaseTerm)\n\t\t\treturn [this.exp];\n\n\t\treturn [];\n\t}\n};\n\n\nexport class SchemeFunction extends BaseTerm {\n\tfunc: (string | BaseTerm);\n\targs: (boolean | string | BaseTerm)[];\n\n\n\tserialize () {\n\t\treturn [\n\t\t\t\"(\", \"\\b\",\n\t\t\t...BaseTerm.optionalSerialize(this.func),\n\t\t\t...cc(this.args.map(BaseTerm.serializeScheme)),\n\t\t\t\"\\b\", \")\",\n\t\t];\n\t}\n\n\n\tquery (key: string): any {\n\t\tif (key === this.func) {\n\t\t\tconst term = this;\n\n\t\t\treturn {\n\t\t\t\tget value () {\n\t\t\t\t\treturn term.args.length === 1 ? term.args[0] : term.args;\n\t\t\t\t},\n\n\t\t\t\tset value (value) {\n\t\t\t\t\tif (term.args.length === 1)\n\t\t\t\t\t\tterm.args[0] = value as string|BaseTerm;\n\t\t\t\t\telse\n\t\t\t\t\t\tterm.args = value as (string|BaseTerm)[];\n\t\t\t\t},\n\t\t\t};\n\t\t}\n\t}\n\n\n\tget asList (): (boolean | string | BaseTerm)[] {\n\t\treturn [this.func, ...this.args];\n\t}\n\n\n\tget entries () {\n\t\treturn this.asList.filter(term => term instanceof BaseTerm) as BaseTerm[];\n\t}\n};\n\n\nexport class SchemePair extends BaseTerm {\n\tleft: any;\n\tright: any;\n\n\n\tserialize () {\n\t\treturn [\n\t\t\t\"(\", \"\\b\",\n\t\t\t...BaseTerm.optionalSerialize(this.left), \".\", ...BaseTerm.optionalSerialize(this.right),\n\t\t\t\"\\b\", \")\",\n\t\t];\n\t}\n};\n\n\nexport class SchemePointer extends BaseTerm {\n\tvalue: any;\n\n\n\tserialize () {\n\t\tconst content = this.value === null ? [\"()\"] : BaseTerm.optionalSerialize(this.value);\n\n\t\treturn [\n\t\t\t\"'\", \"\\b\", ...content,\n\t\t];\n\t}\n\n\n\tget entries () {\n\t\tif (this.value instanceof BaseTerm)\n\t\t\treturn [this.value];\n\n\t\treturn [];\n\t}\n};\n\n\nexport class SchemeEmbed extends BaseTerm {\n\tvalue: Root;\n\n\n\tserialize () {\n\t\treturn [\n\t\t\t\"#{\",\n\t\t\t...BaseTerm.optionalSerialize(this.value),\n\t\t\t\"#}\",\n\t\t];\n\t}\n};\n\n\nexport class Assignment extends BaseTerm {\n\tkey: (string|any[]);\n\tvalue: any;\n\n\n\tconstructor (data) {\n\t\tsuper(data);\n\n\t\tif (this.value instanceof BaseTerm)\n\t\t\tthis.value._parent = this;\n\t}\n\n\n\tserialize () {\n\t\tconst keys = (Array.isArray(this.key) ? this.key : [this.key]).map(BaseTerm.optionalSerialize);\n\t\tconst values = (Array.isArray(this.value) ? this.value : [this.value]).map(BaseTerm.optionalSerialize);\n\n\t\treturn [\n\t\t\t...cc(keys),\n\t\t\t\"=\",\n\t\t\t...cc(values),\n\t\t];\n\t}\n\n\n\tget entries () {\n\t\tif (this.value instanceof BaseTerm)\n\t\t\treturn [this.value];\n\n\t\treturn null;\n\t}\n\n\n\tquery (key) {\n\t\tif (this.key === key) {\n\t\t\tconst term = this;\n\n\t\t\treturn {\n\t\t\t\tget value () {\n\t\t\t\t\treturn term.value;\n\t\t\t\t},\n\n\t\t\t\tset value (value) {\n\t\t\t\t\tterm.value = value;\n\t\t\t\t},\n\t\t\t};\n\t\t}\n\t}\n};\n\n\nexport class MusicEvent extends BaseTerm {\n\tduration?: Duration;\n\tpost_events?: (string | PostEvent)[];\n\n\tdeclare _previous?: MusicEvent;\n\t//_anchorPitch?: ChordElement;\n\t_lastMeasure?: number;\n\n\n\tconstructor (data: object) {\n\t\tsuper(data);\n\n\t\tif (this.post_events)\n\t\t\tthis.post_events = this.post_events.map(parseRaw);\n\t}\n\n\n\tgetPreviousT (T) {\n\t\tif (this._previous instanceof T)\n\t\t\treturn this._previous;\n\n\t\tif (this._previous)\n\t\t\treturn this._previous.getPreviousT(T);\n\t}\n\n\n\tget durationValue (): Duration {\n\t\treturn this.duration || (this._previous ? this._previous.durationValue : Duration.default);\n\t}\n\n\n\tget durationMagnitude (): number {\n\t\treturn this.durationValue.magnitude;\n\t}\n\n\n\tget division (): number {\n\t\treturn this.durationValue.division;\n\t}\n\n\n\tget withMultiplier () {\n\t\treturn this.duration && this.duration.withMultiplier;\n\t}\n\n\n\tget isMusic (): boolean {\n\t\treturn true;\n\t}\n\n\n\tget isTying (): boolean {\n\t\treturn this.post_events && this.post_events.some(event => event instanceof PostEvent && event.isTying);\n\t}\n\n\n\tget isStaccato (): boolean {\n\t\treturn this.post_events && this.post_events.some(event => event instanceof PostEvent && event.isStaccato);\n\t}\n\n\n\t// to be implement in derived classes\n\tget isRest (): boolean {\n\t\treturn null;\n\t}\n\n\n\tget beamOn (): boolean {\n\t\treturn this.post_events && this.post_events.includes(\"[\");\n\t}\n\n\n\tget beamOff (): boolean {\n\t\treturn this.post_events && this.post_events.includes(\"]\");\n\t}\n\n\n\tget measures (): number[] {\n\t\tif (!Number.isFinite(this._measure) || !Number.isFinite(this._lastMeasure))\n\t\t\treturn [];\n\n\t\treturn Array(this._lastMeasure + 1 - this._measure).fill(null).map((_, i) => this._measure + i);\n\t}\n\n\n\tget measureLayout (): measureLayout.MeasureLayout {\n\t\tif (this.measures.length > 1)\n\t\t\treturn measureLayout.BlockMLayout.fromSeq(this.measures.map(measure => measureLayout.SingleMLayout.from(measure)));\n\n\t\tif (this.measures.length === 1)\n\t\t\treturn measureLayout.SingleMLayout.from(this._measure);\n\n\t\treturn null;\n\t}\n\n\n\tget implicitType (): ImplicitType {\n\t\tif (this.post_events) {\n\t\t\tfor (const event of this.post_events) {\n\t\t\t\tif (event instanceof PostEvent && event.arg instanceof Command) {\n\t\t\t\t\tswitch (event.arg.cmd) {\n\t\t\t\t\tcase \"startTrillSpan\":\n\t\t\t\t\tcase \"trill\":\n\t\t\t\t\t\treturn ImplicitType.Trill;\n\n\t\t\t\t\tcase \"turn\":\n\t\t\t\t\t\treturn ImplicitType.Turn;\n\n\t\t\t\t\tcase \"mordent\":\n\t\t\t\t\t\treturn ImplicitType.Mordent;\n\n\t\t\t\t\tcase \"prall\":\n\t\t\t\t\t\treturn ImplicitType.Prall;\n\n\t\t\t\t\t// Arpeggio is not implemented in 'articulate.ly' yet\n\t\t\t\t\tcase \"arpeggio\":\n\t\t\t\t\t\treturn ImplicitType.Arpeggio;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn ImplicitType.None;\n\t}\n\n\n\tget clarified (): MusicEvent {\n\t\tconst clarified = this instanceof Chord ? this.clarifiedChord : this.clone();\n\t\tclarified.duration = this.durationValue && this.durationValue.clone();\n\n\t\treturn clarified;\n\t}\n};\n\n\nexport class Chord extends MusicEvent {\n\tpitches: (ChordElement | Command)[];\n\toptions: {\n\t\texclamations?: string[],\n\t\tquestions?: string[],\n\t\trest?: string,\n\t\twithAngle?: boolean,\n\t};\n\n\n\tconstructor (data) {\n\t\tsuper(data);\n\n\t\tthis.connectPitches();\n\t}\n\n\n\tconnectPitches () {\n\t\tif (this.basePitch)\n\t\t\tthis.basePitch._parent = this;\n\t\tfor (let i = 1; i < this.pitchElements.length; ++i)\n\t\t\tthis.pitchElements[i]._previous = this.pitchElements[i - 1];\n\t}\n\n\n\tget single (): boolean {\n\t\treturn this.pitches.length === 1;\n\t}\n\n\n\tget entries () {\n\t\tconst list: any[] = [...this.pitches];\n\t\tif (Array.isArray(this.post_events))\n\t\t\tlist.push(...this.post_events);\n\n\t\treturn list;\n\t}\n\n\n\tserialize () {\n\t\tconst innerPitches = this.pitches.map(BaseTerm.optionalSerialize);\n\t\tconst pitches = (this.single && !this.options.withAngle) ? cc(innerPitches) : [\n\t\t\t\"<\", \"\\b\", ...cc(innerPitches), \"\\b\", \">\",\n\t\t];\n\n\t\tconst {exclamations, questions, rest} = this.options;\n\t\tconst postfix = cc([...(exclamations || []), ...(questions || []), ...BaseTerm.optionalSerialize(this.duration), rest]\n\t\t\t.filter(item => item)\n\t\t\t.map(item => [\"\\b\", item]),\n\t\t).concat(...(this.post_events || []).map(BaseTerm.optionalSerialize));\n\n\t\treturn [\n\t\t\tnew OpenLocator(this),\n\t\t\t...pitches,\n\t\t\t...postfix,\n\t\t\tnew CloseLocator(this),\n\t\t];\n\t}\n\n\n\tget pitchElements (): ChordElement[] {\n\t\treturn this.pitches.filter(pitch => pitch instanceof ChordElement) as ChordElement[];\n\t}\n\n\n\tget pitchNames (): string[] {\n\t\treturn this.pitchElements.map((elem: ChordElement) => elem.pitch.replace(/'|,/g, \"\"));\n\t}\n\n\n\tget basePitch (): ChordElement {\n\t\treturn this.pitchElements[0];\n\t}\n\n\n\tget absolutePitch (): ChordElement {\n\t\tconsole.assert(!!this.basePitch, \"absolutePitch on non pitch:\", this.join());\n\t\treturn this.basePitch.absolutePitch;\n\t}\n\n\n\tget anchorPitch (): ChordElement {\n\t\tif (this._anchorPitch)\n\t\t\treturn this._anchorPitch;\n\n\t\tconst previous = this.getPreviousT(Chord);\n\t\tif (previous)\n\t\t\treturn previous.absolutePitch;\n\n\t\treturn this.basePitch;\n\t}\n\n\n\tget isRest (): boolean {\n\t\treturn !!this.options.rest;\n\t}\n\n\n\tget completeTied (): boolean {\n\t\treturn this.pitchElements.filter(pitch => !pitch._tied).length === 0;\n\t}\n\n\n\tget pitchesValue (): (ChordElement | Command)[] {\n\t\tif (this._previous instanceof Chord && this.basePitch.pitch === \"q\") {\n\t\t\tconst pitches = this._previous.pitchesValue.map(pitch => {\n\t\t\t\tconst newPitch = pitch.clone();\n\t\t\t\tif (newPitch instanceof ChordElement) {\n\t\t\t\t\tnewPitch._location = this.basePitch._location;\n\t\t\t\t\tnewPitch._tied = this.basePitch._tied;\n\t\t\t\t\tnewPitch._parent = (pitch as ChordElement)._parent && this;\n\t\t\t\t\tnewPitch._previous = (pitch as ChordElement)._previous;\n\t\t\t\t}\n\n\t\t\t\treturn newPitch;\n\t\t\t});\n\t\t\tconst base = pitches.find(pitch => pitch instanceof ChordElement) as ChordElement;\n\t\t\tif (base)\n\t\t\t\tbase.pitch = base.pitch.replace(/[,']/g, \"\");\n\n\t\t\treturn pitches;\n\t\t}\n\n\t\treturn this.pitches;\n\t}\n\n\n\tget clarifiedChord (): MusicEvent {\n\t\tconst clarified = this.clone();\n\t\tclarified.pitches = this.pitchesValue.filter(pitch => !(pitch as ChordElement)._tied).map(pitch => pitch.clone());\n\t\tclarified.connectPitches();\n\n\t\t// replace by rest if all pitches tied\n\t\tif (!clarified.pitches.length)\n\t\t\treturn new Rest({name: \"r\", duration: this.duration});\n\n\t\treturn clarified;\n\t}\n\n\n\tshiftAnchor (newAnchor: ChordElement) {\n\t\t//console.warn(\"shiftAnchor:\", this.join(), newAnchor.join(), this.absolutePitch.pitchValue, newAnchor.pitchValue, this.anchorPitch.pitchValue);\n\t\tconst _location = this.basePitch._location;\n\t\tconst shift = idioms.phonetDifferToShift(this.basePitch.phonetStep - newAnchor.phonetStep);\n\t\tconst relativeOctave = this.basePitch.absoluteOctave(this.anchorPitch) - newAnchor.octave - shift;\n\t\t//console.log(\"_location:\", _location);\n\n\t\tthis.pitches[0] = ChordElement.from({\n\t\t\tphonet: this.basePitch.phonet,\n\t\t\talters: this.basePitch.alters,\n\t\t\toctave: relativeOctave,\n\t\t});\n\n\t\tthis.pitches[0]._location = _location;\n\t\tthis.pitches[0]._parent = this;\n\n\t\tthis.connectPitches();\n\n\t\t//console.log(\"shiftAnchor.1:\", this.join(), this.absolutePitch.pitchValue, {relativeOctave, shift, \"newAnchor.octave\": newAnchor.octave});\n\t}\n\n\n\tmakeRelativeTo (from: ChordElement) {\n\t\tconst _location = this.basePitch._location;\n\n\t\tconst octave = this.basePitch.relativeOctave(from);\n\t\tthis.pitches[0] = ChordElement.from({\n\t\t\tphonet: this.basePitch.phonet,\n\t\t\talters: this.basePitch.alters,\n\t\t\toctave,\n\t\t});\n\n\t\tthis.pitches[0]._location = _location;\n\t\tthis.pitches[0]._parent = this;\n\t}\n};\n\n\nexport class Rest extends MusicEvent {\n\tname: string;\n\n\n\tserialize () {\n\t\treturn [\n\t\t\tnew OpenLocator(this),\n\t\t\t...compact([\n\t\t\t\tthis.name,\n\t\t\t\t...BaseTerm.optionalSerialize(this.duration),\n\t\t\t]),\n\t\t\t...cc((this.post_events || []).map(BaseTerm.optionalSerialize)),\n\t\t\tnew CloseLocator(this),\n\t\t];\n\t}\n\n\n\tget isSpacer () {\n\t\treturn this.name === \"s\";\n\t}\n\n\n\tget isRest (): boolean {\n\t\treturn true;\n\t}\n};\n\n\nexport class ChordElement extends BaseTerm {\n\tpitch: string;\n\toptions: {\n\t\texclamations?: string[],\n\t\tquestions?: string[],\n\t\tpost_events?: PostEvent[],\n\t};\n\n\tdeclare _parent?: Chord;\n\tdeclare _previous?: ChordElement;\n\t_tied?: MusicEvent;\n\t_transposition?: number;\n\n\t// cache for property of absolutePitch\n\t_absolutePitch?: ChordElement;\n\n\n\tstatic from ({phonet, alters = \"\", octave, options = {}}): ChordElement {\n\t\tconst octaveString = octave ? Array(Math.abs(octave)).fill(octave > 0 ? \"'\" : \",\").join(\"\") : \"\";\n\t\tconst pitch = phonet + (alters || \"\") + octaveString;\n\n\t\treturn new ChordElement({pitch, options: {...options, proto: \"_PLAIN\"}});\n\t}\n\n\n\tstatic get default (): ChordElement {\n\t\treturn ChordElement.from({phonet: \"c\", octave: 0});\n\t}\n\n\n\tconstructor (data: object) {\n\t\tsuper(data);\n\n\t\tif (this.options.post_events)\n\t\t\tthis.options.post_events = this.options.post_events.map(parseRaw);\n\n\t\tif (!this.pitch)\n\t\t\tconsole.log(\"null pitch:\", this);\n\t}\n\n\n\tserialize () {\n\t\tconst {exclamations, questions, post_events} = this.options;\n\t\tconst postfix = [].concat(...[...(exclamations || []), ...(questions || [])]\n\t\t\t.filter(item => item)\n\t\t\t.map(item => [\"\\b\", item]),\n\t\t).concat(...(post_events || []).map(item => [\"\\b\", ...BaseTerm.optionalSerialize(item)]));\n\n\t\treturn [\n\t\t\tnew OpenLocator(this),\n\t\t\tthis.pitch,\n\t\t\t...postfix,\n\t\t\tnew CloseLocator(this),\n\t\t];\n\t}\n\n\n\tget octave (): number {\n\t\tconst positive = (this.pitch.match(/'/g) || []).length;\n\t\tconst negative = (this.pitch.match(/,/g) || []).length;\n\n\t\treturn positive - negative;\n\t}\n\n\n\tget phonet (): string {\n\t\tconst ph = this.pitch.substr(0, 1);\n\n\t\treturn idioms.PHONETS_ALIAS[ph] || ph;\n\t}\n\n\n\tget phonetStep (): number {\n\t\treturn idioms.PHONETS.indexOf(this.phonet);\n\t}\n\n\n\tget alters (): string {\n\t\tconst captures = this.pitch.substr(1).match(/^\\w+/);\n\t\treturn captures && captures[0];\n\t}\n\n\n\tget alteredPhonet (): string {\n\t\tconst captures = this.pitch.match(/^\\w+/);\n\t\treturn captures && captures[0];\n\t}\n\n\n\tget anchorPitch (): ChordElement {\n\t\tif (this._previous)\n\t\t\treturn this._previous.absolutePitch;\n\n\t\tif (this._parent)\n\t\t\treturn this._parent.anchorPitch;\n\n\t\treturn ChordElement.from({phonet: this.phonet, octave: 0});\n\t}\n\n\n\tgetAbsolutePitch (): ChordElement {\n\t\tif (this.phonet === \"q\")\n\t\t\treturn this.anchorPitch;\n\n\t\tif (this.anchorPitch === this)\n\t\t\treturn this;\n\n\t\tconst octave = this.absoluteOctave(this.anchorPitch);\n\n\t\treturn ChordElement.from({phonet: this.phonet, alters: this.alters, octave});\n\t}\n\n\n\tget absolutePitch (): ChordElement {\n\t\tif (!this._absolutePitch)\n\t\t\tthis._absolutePitch = this.getAbsolutePitch();\n\n\t\treturn this._absolutePitch;\n\t}\n\n\n\tabsoluteOctave (anchor: ChordElement): number {\n\t\tif (this.phonet === \"q\")\n\t\t\treturn anchor.octave;\n\n\t\tconst phonetDiffer = this.phonetStep - anchor.phonetStep;\n\t\tconst shift = idioms.phonetDifferToShift(phonetDiffer);\n\n\t\treturn anchor.octave + shift + this.octave;\n\t}\n\n\n\trelativeOctave (from: ChordElement): number {\n\t\tif (this.phonet === \"q\") {\n\t\t\tif (this.anchorPitch)\n\t\t\t\treturn this.anchorPitch.relativeOctave(from);\n\t\t\telse\n\t\t\t\treturn 0;\n\t\t}\n\n\t\tconst phonetDiffer = this.phonetStep - from.phonetStep;\n\t\tconst shift = idioms.phonetDifferToShift(phonetDiffer);\n\n\t\treturn this.octave - shift - from.octave;\n\t}\n\n\n\tget alterValue (): number {\n\t\treturn idioms.ALTER_VALUES[this.alters] || 0;\n\t}\n\n\n\tget pitchValue (): number {\n\t\tconst phonetValue = idioms.PHONET_VALUES[this.phonet];\n\t\tconsole.assert(Number.isInteger(phonetValue), \"invalid phonet:\", this.phonet);\n\t\tconsole.assert(!this.alters || idioms.ALTER_VALUES[this.alters], \"invalid alters:\", this.alters);\n\n\t\treturn 48 + this.octave * 12 + phonetValue + this.alterValue;\n\t}\n\n\n\tget absolutePitchValue (): number {\n\t\treturn this.absolutePitch.pitchValue;\n\t}\n\n\n\t// middle C is zero\n\tget notePosition (): number {\n\t\tconst phonet = idioms.PHONETS.indexOf(this.phonet);\n\n\t\treturn (this.octave - 1) * 7 + phonet;\n\t}\n\n\n\tget absoluteNotePosition (): number {\n\t\treturn this.absolutePitch.notePosition;\n\t}\n\n\n\tget tiedParent (): ChordElement {\n\t\tif (!this._tied || !(this._tied instanceof Chord))\n\t\t\treturn null;\n\n\t\tconst pitch = this._tied.pitchElements.find(p => p.absolutePitchValue === this.absolutePitchValue);\n\t\tif (!pitch)\n\t\t\treturn null;\n\n\t\tif (pitch._tied)\n\t\t\treturn pitch.tiedParent;\n\n\t\treturn pitch;\n\t}\n};\n\n\nexport class Duration extends BaseTerm {\n\tnumber: string;\n\tdots: number;\n\tmultipliers?: string[];\n\n\n\tstatic _default: Duration;\n\tstatic get default (): Duration {\n\t\tif (!Duration._default)\n\t\t\tDuration._default = new Duration({number: 4, dots: 0});\n\n\t\treturn Duration._default;\n\t}\n\n\n\tstatic fromMagnitude (magnitude: number): Duration {\n\t\tconst MULTI = 1024;\n\t\tconst MULTI_DURATION_MAGNITUDE = WHOLE_DURATION_MAGNITUDE * MULTI;\n\t\tconst multiMag = magnitude * MULTI;\n\t\tif (!Number.isInteger(multiMag)) {\n\t\t\tconsole.warn(\"magnitude must be integer:\", magnitude);\n\t\t\treturn null;\n\t\t}\n\n\t\tconst di = gcd(multiMag, MULTI_DURATION_MAGNITUDE);\n\t\tconst denominator = MULTI_DURATION_MAGNITUDE / di;\n\t\tconst numerator = multiMag / di;\n\t\tif (!Number.isInteger(Math.log2(denominator)))\n\t\t\treturn new Duration({number: 1, dots: 0, multipliers: [`${numerator}/${denominator}`]});\n\n\t\tswitch (numerator) {\n\t\tcase 1:\n\t\t\treturn new Duration({number: denominator, dots: 0});\n\n\t\tcase 3:\n\t\t\treturn new Duration({number: denominator / 2, dots: 1});\n\n\t\tcase 7:\n\t\t\treturn new Duration({number: denominator / 4, dots: 2});\n\n\t\tdefault:\n\t\t\treturn new Duration({number: denominator, dots: 0, multipliers: [numerator.toString()]});\n\t\t}\n\t}\n\n\n\tserialize () {\n\t\tconst dots = Array(this.dots).fill(\".\").join(\"\");\n\t\tconst multipliers = this.multipliers && this.multipliers.map(multiplier => `*${multiplier}`).join(\"\");\n\n\t\treturn compact([\n\t\t\tthis.number, dots, multipliers,\n\t\t]);\n\t}\n\n\n\tget withMultiplier () {\n\t\treturn this.multipliers && this.multipliers.length > 0;\n\t}\n\n\n\tget denominator (): number {\n\t\tswitch (this.number) {\n\t\tcase \"\\\\breve\":\n\t\t\treturn 0.5;\n\n\t\tcase \"\\\\longa\":\n\t\t\treturn 0.25;\n\t\t}\n\n\t\treturn Number(this.number);\n\t}\n\n\n\tget division (): number {\n\t\treturn Math.log2(this.denominator);\n\t}\n\n\n\t// how many smallest rhythm unit in a whole note\n\tget subdivider (): number {\n\t\treturn this.denominator * (2 ** this.dots);\n\t}\n\n\n\tget magnitude (): number {\n\t\tlet value = WHOLE_DURATION_MAGNITUDE / this.denominator;\n\n\t\tif (this.dots)\n\t\t\tvalue *= 2 - 0.5 ** this.dots;\n\n\t\tif (this.multipliers)\n\t\t\tthis.multipliers.forEach(multiplier => value *= eval(multiplier));\n\n\t\treturn value;\n\t}\n};\n\n\ninterface BriefChordBody {\n\tpitch: string;\n\tduration: Duration;\n\tseparator: string;\n\titems: string[];\n};\n\n\nexport class BriefChord extends BaseTerm {\n\tbody: BriefChordBody;\n\tpost_events: any[];\n\n\n\tconstructor (data: object) {\n\t\tsuper(data);\n\n\t\tif (this.body)\n\t\t\tthis.body.duration = parseRaw(this.body.duration);\n\t}\n\n\n\tserialize () {\n\t\tconst {pitch, duration, separator, items} = this.body;\n\n\t\treturn [\n\t\t\t...compact(cc([pitch, duration, separator, ...(items || [])].map(BaseTerm.optionalSerialize))),\n\t\t\t...cc((this.post_events || []).map(BaseTerm.optionalSerialize)),\n\t\t];\n\t}\n\n\n\tget isMusic (): boolean {\n\t\treturn true;\n\t}\n\n\n\tget durationMagnitude (): number {\n\t\tif (this.body.duration)\n\t\t\treturn this.body.duration.magnitude;\n\n\t\treturn 0;\n\t}\n};\n\n\nexport class NumberUnit extends BaseTerm {\n\tnumber: number;\n\tunit: string;\n\n\n\tserialize () {\n\t\treturn [this.number, \"\\b\", this.unit];\n\t}\n\n\n\tset ({number, unit}) {\n\t\tthis.number = Number(number.toFixed(2));\n\n\t\tif (unit !== undefined)\n\t\t\tthis.unit = unit;\n\t}\n}\n\n\nexport class Tempo extends BaseTerm {\n\tbeatsPerMinute?: number;\n\tunit?: Duration;\n\ttext?: string;\n\n\n\tstatic fromNoteBpm (note: number, bpm: number): Tempo {\n\t\treturn new Tempo ({\n\t\t\tunit: new Duration({number: note.toString(), dots: 0}),\n\t\t\tbeatsPerMinute: bpm,\n\t\t});\n\t}\n\n\n\tserialize () {\n\t\tconst assignment = Number.isFinite(this.beatsPerMinute) ? [...BaseTerm.optionalSerialize(this.unit), \"=\", this.beatsPerMinute] : [];\n\n\t\treturn [\n\t\t\t\"\\\\tempo\",\n\t\t\t...BaseTerm.optionalSerialize(this.text),\n\t\t\t...assignment,\n\t\t];\n\t}\n}\n\n\nconst DIRECTION_CHAR = {\n\tup: \"^\",\n\tdown: \"_\",\n\tmiddle: \"-\",\n};\n\n\nexport class PostEvent extends BaseTerm {\n\tdirection: string;\n\targ: string | BaseTerm;\n\n\n\tserialize () {\n\t\tconst dir = DIRECTION_CHAR[this.direction];\n\t\tconst prefix = dir ? [dir, \"\\b\"] : [];\n\n\t\treturn prefix.concat(BaseTerm.optionalSerialize(this.arg));\n\t}\n\n\n\tget entries () {\n\t\tif (this.arg instanceof BaseTerm)\n\t\t\treturn [this.arg];\n\n\t\treturn null;\n\t}\n\n\n\tget isTying (): boolean {\n\t\treturn this.arg === \"~\";\n\t}\n\n\n\tget isStaccato (): boolean {\n\t\tif (this.arg instanceof Command)\n\t\t\treturn [\"staccato\", \"staccatissimo\", \"portato\"].includes(this.arg.cmd);\n\n\t\tif ([\".\", \"!\"].includes(this.arg as string))\n\t\t\treturn true;\n\n\t\treturn false;\n\t}\n};\n\n\nexport class Fingering extends BaseTerm {\n\tvalue: number;\n\n\n\tserialize () {\n\t\treturn [this.value];\n\t}\n};\n\n\nexport class Markup extends BaseTerm {\n\thead: any[];\n\tbody: (string|BaseTerm);\n\n\n\tserialize () {\n\t\treturn [\n\t\t\t...cc(this.head.map(BaseTerm.optionalSerialize)),\n\t\t\t...BaseTerm.optionalSerialize(this.body),\n\t\t];\n\t}\n};\n\n\nexport class Lyric extends MusicEvent {\n\tcontent: string | LiteralString;\n\n\n\tserialize () {\n\t\treturn [\n\t\t\t...BaseTerm.optionalSerialize(this.content),\n\t\t\t...BaseTerm.optionalSerialize(this.duration),\n\t\t\t...cc((this.post_events || []).map(BaseTerm.optionalSerialize)),\n\t\t];\n\t}\n};\n\n\nexport class Comment extends BaseTerm {\n\ttext: string;\n\tscoped: boolean;\n\n\n\tserialize () {\n\t\treturn [\n\t\t\tthis.text,\n\t\t\t\"\\n\",\n\t\t];\n\t}\n\n\n\tstatic createSingle (text): Comment {\n\t\treturn new Comment({text: \"%\" + text});\n\t}\n\n\n\tstatic createScoped (text): Comment {\n\t\tconsole.assert(!/%\\}/.test(text), \"invalid scoped comment text:\", text);\n\n\t\treturn new Comment({text: `%{${text}%}`, scoped: true});\n\t}\n};\n\n\nexport class Unexpect extends BaseTerm {\n\tconstructor (data) {\n\t\tsuper(data);\n\n\t\tconsole.warn(\"unexpected term\", data);\n\t}\n};\n\n\nexport const termDictionary = {\n\tRoot,\n\tLiteralString,\n\tCommand,\n\tVariable,\n\tMarkupCommand,\n\tRepeat,\n\tRelative,\n\tParallelMusic,\n\tTimeSignature,\n\tPartial,\n\tTimes,\n\tTuplet,\n\tGrace,\n\tAfterGrace,\n\tClef,\n\tKeySignature,\n\tOctaveShift,\n\tInclude,\n\tVersion,\n\tLanguage,\n\tLyricMode,\n\tChordMode,\n\tTransposition,\n\tStemDirection,\n\tChange,\n\tBlock,\n\tInlineBlock,\n\tScheme,\n\tSchemeFunction,\n\tSchemePair,\n\tSchemePointer,\n\tSchemeEmbed,\n\tAssignment,\n\tDuration,\n\tChordElement,\n\tChord,\n\tRest,\n\tBriefChord,\n\tNumberUnit,\n\tMusicBlock,\n\tSimultaneousList,\n\tContextedMusic,\n\tDivide,\n\tTempo,\n\tPostEvent,\n\tFingering,\n\tMarkup,\n\tLyric,\n\tPrimitive,\n\tComment,\n};\n\n\nconst termProtoMap: Map<object, string> = Object.entries(termDictionary)\n\t.reduce((map, [name, cls]: [string, {prototype: object}]) => (map.set(cls.prototype, name), map), new Map());\n\n\nconst parseRawEnforce = data => {\n\tswitch (typeof data) {\n\tcase \"string\":\n\tcase \"number\":\n\t\treturn new Primitive({exp: data});\n\n\tdefault:\n\t\treturn parseRaw(data);\n\t}\n};\n\n\nexport const parseRaw = data => {\n\tif (data instanceof BaseTerm)\n\t\treturn data;\n\n\tif (!data)\n\t\treturn data;\n\n\tswitch (typeof data) {\n\tcase \"object\":\n\t\tif (Array.isArray(data))\n\t\t\treturn data.map(item => parseRaw(item));\n\n\t\tconst {proto, ...fields} = data;\n\t\tif (proto) {\n\t\t\tif (proto === \"_PLAIN\")\n\t\t\t\treturn fields;\n\n\t\t\tconst termClass = termDictionary[proto];\n\t\t\tif (!termClass)\n\t\t\t\tthrow new Error(`Unexpected term class: ${data.proto}`);\n\n\t\t\treturn new termClass(fields);\n\t\t}\n\n\t\treturn new Unexpect(data); \n\t}\n\n\treturn data;\n};\n"],"mappings":"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","ignoreList":[]}]}