add initial marp implementation with sample content and build configuration
This commit is contained in:
42
node_modules/speech-rule-engine/js/audio/xml_renderer.js
generated
vendored
Normal file
42
node_modules/speech-rule-engine/js/audio/xml_renderer.js
generated
vendored
Normal file
@@ -0,0 +1,42 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.XmlRenderer = void 0;
|
||||
const engine_js_1 = require("../common/engine.js");
|
||||
const AudioUtil = require("./audio_util.js");
|
||||
const markup_renderer_js_1 = require("./markup_renderer.js");
|
||||
class XmlRenderer extends markup_renderer_js_1.MarkupRenderer {
|
||||
markup(descrs) {
|
||||
this.setScaleFunction(-2, 2, -100, 100, 2);
|
||||
const markup = AudioUtil.personalityMarkup(descrs);
|
||||
const result = [];
|
||||
const currentOpen = [];
|
||||
for (let i = 0, descr; (descr = markup[i]); i++) {
|
||||
if (descr.span) {
|
||||
result.push(this.merge(descr.span));
|
||||
continue;
|
||||
}
|
||||
if (AudioUtil.isPauseElement(descr)) {
|
||||
result.push(this.pause(descr));
|
||||
continue;
|
||||
}
|
||||
if (descr.close.length) {
|
||||
for (let j = 0; j < descr.close.length; j++) {
|
||||
const last = currentOpen.pop();
|
||||
if (descr.close.indexOf(last) === -1) {
|
||||
throw new engine_js_1.SREError('Unknown closing markup element: ' + last);
|
||||
}
|
||||
result.push(this.closeTag(last));
|
||||
}
|
||||
}
|
||||
if (descr.open.length) {
|
||||
const open = AudioUtil.sortClose(descr.open.slice(), markup.slice(i + 1));
|
||||
open.forEach((o) => {
|
||||
result.push(this.prosodyElement(o, descr[o]));
|
||||
currentOpen.push(o);
|
||||
});
|
||||
}
|
||||
}
|
||||
return result.join(' ');
|
||||
}
|
||||
}
|
||||
exports.XmlRenderer = XmlRenderer;
|
||||
Reference in New Issue
Block a user