2020-09-20 15:33:12 +00:00
|
|
|
|
/*
|
2021-01-01 19:50:41 +00:00
|
|
|
|
* Copyright (C) 2020-2021 Yomichan Authors
|
2020-09-20 15:33:12 +00:00
|
|
|
|
*
|
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
|
* (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
const fs = require('fs');
|
|
|
|
|
const url = require('url');
|
|
|
|
|
const path = require('path');
|
|
|
|
|
const assert = require('assert');
|
2020-11-07 16:34:14 +00:00
|
|
|
|
const {testMain} = require('../dev/util');
|
2020-09-20 15:33:12 +00:00
|
|
|
|
const {VM} = require('../dev/vm');
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function createVM(extDir) {
|
|
|
|
|
const chrome = {
|
|
|
|
|
runtime: {
|
|
|
|
|
getURL(path2) {
|
|
|
|
|
return url.pathToFileURL(path.join(extDir, path2.replace(/^\//, ''))).href;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
async function fetch(url2) {
|
|
|
|
|
const filePath = url.fileURLToPath(url2);
|
|
|
|
|
await Promise.resolve();
|
|
|
|
|
const content = fs.readFileSync(filePath, {encoding: null});
|
|
|
|
|
return {
|
|
|
|
|
ok: true,
|
|
|
|
|
status: 200,
|
|
|
|
|
statusText: 'OK',
|
|
|
|
|
text: async () => Promise.resolve(content.toString('utf8')),
|
|
|
|
|
json: async () => Promise.resolve(JSON.parse(content.toString('utf8')))
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const vm = new VM({chrome, fetch});
|
|
|
|
|
vm.execute([
|
2021-02-14 03:52:28 +00:00
|
|
|
|
'js/core.js',
|
|
|
|
|
'js/general/cache-map.js',
|
2021-02-14 16:19:54 +00:00
|
|
|
|
'js/data/json-schema.js',
|
|
|
|
|
'js/templates/template-patcher.js',
|
|
|
|
|
'js/data/options-util.js'
|
2020-09-20 15:33:12 +00:00
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
return vm;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function clone(value) {
|
|
|
|
|
return JSON.parse(JSON.stringify(value));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function createProfileOptionsTestData1() {
|
|
|
|
|
return {
|
2020-10-27 23:26:30 +00:00
|
|
|
|
version: 14,
|
2020-09-20 15:33:12 +00:00
|
|
|
|
general: {
|
|
|
|
|
enable: true,
|
|
|
|
|
enableClipboardPopups: false,
|
|
|
|
|
resultOutputMode: 'group',
|
|
|
|
|
debugInfo: false,
|
|
|
|
|
maxResults: 32,
|
|
|
|
|
showAdvanced: false,
|
|
|
|
|
popupDisplayMode: 'default',
|
|
|
|
|
popupWidth: 400,
|
|
|
|
|
popupHeight: 250,
|
|
|
|
|
popupHorizontalOffset: 0,
|
|
|
|
|
popupVerticalOffset: 10,
|
|
|
|
|
popupHorizontalOffset2: 10,
|
|
|
|
|
popupVerticalOffset2: 0,
|
|
|
|
|
popupHorizontalTextPosition: 'below',
|
|
|
|
|
popupVerticalTextPosition: 'before',
|
|
|
|
|
popupScalingFactor: 1,
|
|
|
|
|
popupScaleRelativeToPageZoom: false,
|
|
|
|
|
popupScaleRelativeToVisualViewport: true,
|
|
|
|
|
showGuide: true,
|
|
|
|
|
compactTags: false,
|
|
|
|
|
compactGlossaries: false,
|
|
|
|
|
mainDictionary: '',
|
|
|
|
|
popupTheme: 'default',
|
|
|
|
|
popupOuterTheme: 'default',
|
|
|
|
|
customPopupCss: '',
|
|
|
|
|
customPopupOuterCss: '',
|
|
|
|
|
enableWanakana: true,
|
|
|
|
|
enableClipboardMonitor: false,
|
|
|
|
|
showPitchAccentDownstepNotation: true,
|
|
|
|
|
showPitchAccentPositionNotation: true,
|
|
|
|
|
showPitchAccentGraph: false,
|
|
|
|
|
showIframePopupsInRootFrame: false,
|
|
|
|
|
useSecurePopupFrameUrl: true,
|
|
|
|
|
usePopupShadowDom: true
|
|
|
|
|
},
|
|
|
|
|
audio: {
|
|
|
|
|
enabled: true,
|
|
|
|
|
sources: ['jpod101'],
|
|
|
|
|
volume: 100,
|
|
|
|
|
autoPlay: false,
|
2021-04-04 20:22:35 +00:00
|
|
|
|
customSourceUrl: 'http://localhost/audio.mp3?term={expression}&reading={reading}',
|
2020-09-20 15:33:12 +00:00
|
|
|
|
textToSpeechVoice: ''
|
|
|
|
|
},
|
|
|
|
|
scanning: {
|
|
|
|
|
middleMouse: true,
|
|
|
|
|
touchInputEnabled: true,
|
|
|
|
|
selectText: true,
|
|
|
|
|
alphanumeric: true,
|
|
|
|
|
autoHideResults: false,
|
|
|
|
|
delay: 20,
|
|
|
|
|
length: 10,
|
|
|
|
|
modifier: 'shift',
|
|
|
|
|
deepDomScan: false,
|
|
|
|
|
popupNestingMaxDepth: 0,
|
|
|
|
|
enablePopupSearch: false,
|
|
|
|
|
enableOnPopupExpressions: false,
|
|
|
|
|
enableOnSearchPage: true,
|
|
|
|
|
enableSearchTags: false,
|
|
|
|
|
layoutAwareScan: false
|
|
|
|
|
},
|
|
|
|
|
translation: {
|
|
|
|
|
convertHalfWidthCharacters: 'false',
|
|
|
|
|
convertNumericCharacters: 'false',
|
|
|
|
|
convertAlphabeticCharacters: 'false',
|
|
|
|
|
convertHiraganaToKatakana: 'false',
|
|
|
|
|
convertKatakanaToHiragana: 'variant',
|
|
|
|
|
collapseEmphaticSequences: 'false'
|
|
|
|
|
},
|
2021-03-31 22:17:28 +00:00
|
|
|
|
dictionaries: {
|
|
|
|
|
'Test Dictionary': {
|
|
|
|
|
priority: 0,
|
|
|
|
|
enabled: true,
|
|
|
|
|
allowSecondarySearches: false
|
|
|
|
|
}
|
|
|
|
|
},
|
2020-09-20 15:33:12 +00:00
|
|
|
|
parsing: {
|
|
|
|
|
enableScanningParser: true,
|
|
|
|
|
enableMecabParser: false,
|
|
|
|
|
selectedParser: null,
|
|
|
|
|
termSpacing: true,
|
|
|
|
|
readingMode: 'hiragana'
|
|
|
|
|
},
|
|
|
|
|
anki: {
|
|
|
|
|
enable: false,
|
|
|
|
|
server: 'http://127.0.0.1:8765',
|
|
|
|
|
tags: ['yomichan'],
|
|
|
|
|
sentenceExt: 200,
|
|
|
|
|
screenshot: {format: 'png', quality: 92},
|
|
|
|
|
terms: {deck: '', model: '', fields: {}},
|
|
|
|
|
kanji: {deck: '', model: '', fields: {}},
|
|
|
|
|
duplicateScope: 'collection',
|
|
|
|
|
fieldTemplates: null
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function createOptionsTestData1() {
|
|
|
|
|
return {
|
|
|
|
|
profiles: [
|
|
|
|
|
{
|
|
|
|
|
name: 'Default',
|
|
|
|
|
options: createProfileOptionsTestData1(),
|
|
|
|
|
conditionGroups: [
|
|
|
|
|
{
|
|
|
|
|
conditions: [
|
|
|
|
|
{
|
|
|
|
|
type: 'popupLevel',
|
|
|
|
|
operator: 'equal',
|
|
|
|
|
value: 1
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'popupLevel',
|
|
|
|
|
operator: 'notEqual',
|
|
|
|
|
value: 0
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'popupLevel',
|
|
|
|
|
operator: 'lessThan',
|
|
|
|
|
value: 3
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'popupLevel',
|
|
|
|
|
operator: 'greaterThan',
|
|
|
|
|
value: 0
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'popupLevel',
|
|
|
|
|
operator: 'lessThanOrEqual',
|
|
|
|
|
value: 2
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'popupLevel',
|
|
|
|
|
operator: 'greaterThanOrEqual',
|
|
|
|
|
value: 1
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
conditions: [
|
|
|
|
|
{
|
|
|
|
|
type: 'url',
|
|
|
|
|
operator: 'matchDomain',
|
|
|
|
|
value: 'example.com'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'url',
|
|
|
|
|
operator: 'matchRegExp',
|
|
|
|
|
value: 'example\\.com'
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
conditions: [
|
|
|
|
|
{
|
|
|
|
|
type: 'modifierKeys',
|
|
|
|
|
operator: 'are',
|
|
|
|
|
value: [
|
|
|
|
|
'ctrl',
|
|
|
|
|
'shift'
|
|
|
|
|
]
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'modifierKeys',
|
|
|
|
|
operator: 'areNot',
|
|
|
|
|
value: [
|
|
|
|
|
'alt',
|
|
|
|
|
'shift'
|
|
|
|
|
]
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'modifierKeys',
|
|
|
|
|
operator: 'include',
|
|
|
|
|
value: 'alt'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'modifierKeys',
|
|
|
|
|
operator: 'notInclude',
|
|
|
|
|
value: 'ctrl'
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
],
|
|
|
|
|
profileCurrent: 0,
|
|
|
|
|
version: 2,
|
|
|
|
|
global: {
|
|
|
|
|
database: {
|
|
|
|
|
prefixWildcardsSupported: false
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function createProfileOptionsUpdatedTestData1() {
|
|
|
|
|
return {
|
|
|
|
|
general: {
|
|
|
|
|
enable: true,
|
|
|
|
|
resultOutputMode: 'group',
|
|
|
|
|
debugInfo: false,
|
|
|
|
|
maxResults: 32,
|
|
|
|
|
showAdvanced: false,
|
|
|
|
|
popupDisplayMode: 'default',
|
|
|
|
|
popupWidth: 400,
|
|
|
|
|
popupHeight: 250,
|
|
|
|
|
popupHorizontalOffset: 0,
|
|
|
|
|
popupVerticalOffset: 10,
|
|
|
|
|
popupHorizontalOffset2: 10,
|
|
|
|
|
popupVerticalOffset2: 0,
|
|
|
|
|
popupHorizontalTextPosition: 'below',
|
|
|
|
|
popupVerticalTextPosition: 'before',
|
|
|
|
|
popupScalingFactor: 1,
|
|
|
|
|
popupScaleRelativeToPageZoom: false,
|
|
|
|
|
popupScaleRelativeToVisualViewport: true,
|
|
|
|
|
showGuide: true,
|
|
|
|
|
compactTags: false,
|
2020-11-26 04:22:05 +00:00
|
|
|
|
glossaryLayoutMode: 'default',
|
2020-09-20 15:33:12 +00:00
|
|
|
|
mainDictionary: '',
|
|
|
|
|
popupTheme: 'default',
|
|
|
|
|
popupOuterTheme: 'default',
|
|
|
|
|
customPopupCss: '',
|
|
|
|
|
customPopupOuterCss: '',
|
|
|
|
|
enableWanakana: true,
|
|
|
|
|
showPitchAccentDownstepNotation: true,
|
|
|
|
|
showPitchAccentPositionNotation: true,
|
|
|
|
|
showPitchAccentGraph: false,
|
|
|
|
|
showIframePopupsInRootFrame: false,
|
|
|
|
|
useSecurePopupFrameUrl: true,
|
|
|
|
|
usePopupShadowDom: true,
|
2020-12-18 16:24:43 +00:00
|
|
|
|
usePopupWindow: false,
|
2020-12-22 23:22:14 +00:00
|
|
|
|
popupCurrentIndicatorMode: 'triangle',
|
2020-12-20 01:07:55 +00:00
|
|
|
|
popupActionBarVisibility: 'auto',
|
2021-02-25 22:48:39 +00:00
|
|
|
|
popupActionBarLocation: 'top',
|
2021-02-27 19:04:52 +00:00
|
|
|
|
frequencyDisplayMode: 'split-tags-grouped',
|
|
|
|
|
termDisplayMode: 'ruby'
|
2020-09-20 15:33:12 +00:00
|
|
|
|
},
|
|
|
|
|
audio: {
|
|
|
|
|
enabled: true,
|
|
|
|
|
sources: ['jpod101'],
|
|
|
|
|
volume: 100,
|
|
|
|
|
autoPlay: false,
|
2021-04-04 20:22:35 +00:00
|
|
|
|
customSourceUrl: 'http://localhost/audio.mp3?term={term}&reading={reading}',
|
2021-01-24 03:46:00 +00:00
|
|
|
|
customSourceType: 'audio',
|
2020-09-20 15:33:12 +00:00
|
|
|
|
textToSpeechVoice: ''
|
|
|
|
|
},
|
|
|
|
|
scanning: {
|
|
|
|
|
touchInputEnabled: true,
|
|
|
|
|
selectText: true,
|
|
|
|
|
alphanumeric: true,
|
|
|
|
|
autoHideResults: false,
|
|
|
|
|
delay: 20,
|
|
|
|
|
length: 10,
|
|
|
|
|
deepDomScan: false,
|
|
|
|
|
popupNestingMaxDepth: 0,
|
|
|
|
|
enablePopupSearch: false,
|
|
|
|
|
enableOnPopupExpressions: false,
|
|
|
|
|
enableOnSearchPage: true,
|
|
|
|
|
enableSearchTags: false,
|
|
|
|
|
layoutAwareScan: false,
|
|
|
|
|
hideDelay: 0,
|
|
|
|
|
pointerEventsEnabled: false,
|
2020-09-26 23:24:21 +00:00
|
|
|
|
preventMiddleMouse: {
|
|
|
|
|
onWebPages: false,
|
|
|
|
|
onPopupPages: false,
|
|
|
|
|
onSearchPages: false,
|
|
|
|
|
onSearchQuery: false
|
|
|
|
|
},
|
2020-09-20 15:33:12 +00:00
|
|
|
|
inputs: [
|
|
|
|
|
{
|
|
|
|
|
include: 'shift',
|
2020-09-26 21:51:52 +00:00
|
|
|
|
exclude: 'mouse0',
|
2020-09-20 15:33:12 +00:00
|
|
|
|
types: {
|
|
|
|
|
mouse: true,
|
|
|
|
|
touch: false,
|
|
|
|
|
pen: false
|
|
|
|
|
},
|
|
|
|
|
options: {
|
|
|
|
|
showAdvanced: false,
|
2020-09-27 15:53:07 +00:00
|
|
|
|
searchTerms: true,
|
|
|
|
|
searchKanji: true,
|
2020-09-27 15:46:37 +00:00
|
|
|
|
scanOnTouchMove: true,
|
2020-09-20 15:33:12 +00:00
|
|
|
|
scanOnPenHover: true,
|
|
|
|
|
scanOnPenPress: true,
|
|
|
|
|
scanOnPenRelease: false,
|
2020-09-27 15:46:37 +00:00
|
|
|
|
preventTouchScrolling: true
|
2020-09-20 15:33:12 +00:00
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
include: 'mouse2',
|
|
|
|
|
exclude: '',
|
|
|
|
|
types: {
|
|
|
|
|
mouse: true,
|
|
|
|
|
touch: false,
|
|
|
|
|
pen: false
|
|
|
|
|
},
|
|
|
|
|
options: {
|
|
|
|
|
showAdvanced: false,
|
2020-09-27 15:53:07 +00:00
|
|
|
|
searchTerms: true,
|
|
|
|
|
searchKanji: true,
|
2020-09-27 15:46:37 +00:00
|
|
|
|
scanOnTouchMove: true,
|
2020-09-20 15:33:12 +00:00
|
|
|
|
scanOnPenHover: true,
|
|
|
|
|
scanOnPenPress: true,
|
|
|
|
|
scanOnPenRelease: false,
|
2020-09-27 15:46:37 +00:00
|
|
|
|
preventTouchScrolling: true
|
2020-09-20 15:33:12 +00:00
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
include: '',
|
|
|
|
|
exclude: '',
|
|
|
|
|
types: {
|
|
|
|
|
mouse: false,
|
|
|
|
|
touch: true,
|
|
|
|
|
pen: true
|
|
|
|
|
},
|
|
|
|
|
options: {
|
|
|
|
|
showAdvanced: false,
|
2020-09-27 15:53:07 +00:00
|
|
|
|
searchTerms: true,
|
|
|
|
|
searchKanji: true,
|
2020-09-27 15:46:37 +00:00
|
|
|
|
scanOnTouchMove: true,
|
2020-09-20 15:33:12 +00:00
|
|
|
|
scanOnPenHover: true,
|
|
|
|
|
scanOnPenPress: true,
|
|
|
|
|
scanOnPenRelease: false,
|
2020-09-27 15:46:37 +00:00
|
|
|
|
preventTouchScrolling: true
|
2020-09-20 15:33:12 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
},
|
|
|
|
|
translation: {
|
|
|
|
|
convertHalfWidthCharacters: 'false',
|
|
|
|
|
convertNumericCharacters: 'false',
|
|
|
|
|
convertAlphabeticCharacters: 'false',
|
|
|
|
|
convertHiraganaToKatakana: 'false',
|
|
|
|
|
convertKatakanaToHiragana: 'variant',
|
2021-01-03 17:12:55 +00:00
|
|
|
|
collapseEmphaticSequences: 'false',
|
|
|
|
|
textReplacements: {
|
|
|
|
|
searchOriginal: true,
|
|
|
|
|
groups: []
|
|
|
|
|
}
|
2020-09-20 15:33:12 +00:00
|
|
|
|
},
|
2021-04-03 17:02:49 +00:00
|
|
|
|
dictionaries: [
|
|
|
|
|
{
|
|
|
|
|
name: 'Test Dictionary',
|
2021-03-31 22:17:28 +00:00
|
|
|
|
priority: 0,
|
|
|
|
|
enabled: true,
|
|
|
|
|
allowSecondarySearches: false,
|
|
|
|
|
definitionsCollapsible: 'not-collapsible'
|
|
|
|
|
}
|
2021-04-03 17:02:49 +00:00
|
|
|
|
],
|
2020-09-20 15:33:12 +00:00
|
|
|
|
parsing: {
|
|
|
|
|
enableScanningParser: true,
|
|
|
|
|
enableMecabParser: false,
|
|
|
|
|
selectedParser: null,
|
|
|
|
|
termSpacing: true,
|
|
|
|
|
readingMode: 'hiragana'
|
|
|
|
|
},
|
|
|
|
|
anki: {
|
|
|
|
|
enable: false,
|
|
|
|
|
server: 'http://127.0.0.1:8765',
|
|
|
|
|
tags: ['yomichan'],
|
|
|
|
|
screenshot: {format: 'png', quality: 92},
|
|
|
|
|
terms: {deck: '', model: '', fields: {}},
|
|
|
|
|
kanji: {deck: '', model: '', fields: {}},
|
|
|
|
|
duplicateScope: 'collection',
|
2021-04-30 21:57:53 +00:00
|
|
|
|
displayTags: 'never',
|
2020-11-08 21:25:07 +00:00
|
|
|
|
checkForDuplicates: true,
|
2021-01-15 03:42:11 +00:00
|
|
|
|
fieldTemplates: null,
|
|
|
|
|
suspendNewCards: false
|
2021-01-10 02:25:04 +00:00
|
|
|
|
},
|
|
|
|
|
sentenceParsing: {
|
2021-01-10 19:43:06 +00:00
|
|
|
|
scanExtent: 200,
|
2021-05-16 19:24:38 +00:00
|
|
|
|
terminationCharacterMode: 'custom',
|
2021-01-10 19:43:06 +00:00
|
|
|
|
terminationCharacters: [
|
|
|
|
|
{enabled: true, character1: '「', character2: '」', includeCharacterAtStart: false, includeCharacterAtEnd: false},
|
|
|
|
|
{enabled: true, character1: '『', character2: '』', includeCharacterAtStart: false, includeCharacterAtEnd: false},
|
|
|
|
|
{enabled: true, character1: '"', character2: '"', includeCharacterAtStart: false, includeCharacterAtEnd: false},
|
|
|
|
|
{enabled: true, character1: '\'', character2: '\'', includeCharacterAtStart: false, includeCharacterAtEnd: false},
|
|
|
|
|
{enabled: true, character1: '.', character2: null, includeCharacterAtStart: false, includeCharacterAtEnd: true},
|
|
|
|
|
{enabled: true, character1: '!', character2: null, includeCharacterAtStart: false, includeCharacterAtEnd: true},
|
|
|
|
|
{enabled: true, character1: '?', character2: null, includeCharacterAtStart: false, includeCharacterAtEnd: true},
|
|
|
|
|
{enabled: true, character1: '.', character2: null, includeCharacterAtStart: false, includeCharacterAtEnd: true},
|
|
|
|
|
{enabled: true, character1: '。', character2: null, includeCharacterAtStart: false, includeCharacterAtEnd: true},
|
|
|
|
|
{enabled: true, character1: '!', character2: null, includeCharacterAtStart: false, includeCharacterAtEnd: true},
|
|
|
|
|
{enabled: true, character1: '?', character2: null, includeCharacterAtStart: false, includeCharacterAtEnd: true},
|
|
|
|
|
{enabled: true, character1: '…', character2: null, includeCharacterAtStart: false, includeCharacterAtEnd: true}
|
|
|
|
|
]
|
2021-01-15 01:56:18 +00:00
|
|
|
|
},
|
|
|
|
|
inputs: {
|
|
|
|
|
hotkeys: [
|
2021-03-28 02:30:45 +00:00
|
|
|
|
{action: 'close', argument: '', key: 'Escape', modifiers: [], scopes: ['popup'], enabled: true},
|
|
|
|
|
{action: 'focusSearchBox', argument: '', key: 'Escape', modifiers: [], scopes: ['search'], enabled: true},
|
|
|
|
|
{action: 'previousEntry', argument: '3', key: 'PageUp', modifiers: ['alt'], scopes: ['popup', 'search'], enabled: true},
|
|
|
|
|
{action: 'nextEntry', argument: '3', key: 'PageDown', modifiers: ['alt'], scopes: ['popup', 'search'], enabled: true},
|
|
|
|
|
{action: 'lastEntry', argument: '', key: 'End', modifiers: ['alt'], scopes: ['popup', 'search'], enabled: true},
|
|
|
|
|
{action: 'firstEntry', argument: '', key: 'Home', modifiers: ['alt'], scopes: ['popup', 'search'], enabled: true},
|
|
|
|
|
{action: 'previousEntry', argument: '1', key: 'ArrowUp', modifiers: ['alt'], scopes: ['popup', 'search'], enabled: true},
|
|
|
|
|
{action: 'nextEntry', argument: '1', key: 'ArrowDown', modifiers: ['alt'], scopes: ['popup', 'search'], enabled: true},
|
|
|
|
|
{action: 'historyBackward', argument: '', key: 'KeyB', modifiers: ['alt'], scopes: ['popup', 'search'], enabled: true},
|
|
|
|
|
{action: 'historyForward', argument: '', key: 'KeyF', modifiers: ['alt'], scopes: ['popup', 'search'], enabled: true},
|
|
|
|
|
{action: 'addNoteKanji', argument: '', key: 'KeyK', modifiers: ['alt'], scopes: ['popup', 'search'], enabled: true},
|
|
|
|
|
{action: 'addNoteTermKanji', argument: '', key: 'KeyE', modifiers: ['alt'], scopes: ['popup', 'search'], enabled: true},
|
|
|
|
|
{action: 'addNoteTermKana', argument: '', key: 'KeyR', modifiers: ['alt'], scopes: ['popup', 'search'], enabled: true},
|
|
|
|
|
{action: 'playAudio', argument: '', key: 'KeyP', modifiers: ['alt'], scopes: ['popup', 'search'], enabled: true},
|
|
|
|
|
{action: 'viewNote', argument: '', key: 'KeyV', modifiers: ['alt'], scopes: ['popup', 'search'], enabled: true},
|
|
|
|
|
{action: 'copyHostSelection', argument: '', key: 'KeyC', modifiers: ['ctrl'], scopes: ['popup'], enabled: true}
|
2021-01-15 01:56:18 +00:00
|
|
|
|
]
|
2021-01-16 15:22:24 +00:00
|
|
|
|
},
|
|
|
|
|
popupWindow: {
|
|
|
|
|
width: 400,
|
|
|
|
|
height: 250,
|
|
|
|
|
left: 0,
|
|
|
|
|
top: 0,
|
|
|
|
|
useLeft: false,
|
|
|
|
|
useTop: false,
|
|
|
|
|
windowType: 'popup',
|
|
|
|
|
windowState: 'normal'
|
2021-01-26 23:30:01 +00:00
|
|
|
|
},
|
|
|
|
|
clipboard: {
|
|
|
|
|
enableBackgroundMonitor: false,
|
|
|
|
|
enableSearchPageMonitor: false,
|
|
|
|
|
autoSearchContent: true,
|
|
|
|
|
maximumSearchLength: 1000
|
2020-09-20 15:33:12 +00:00
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function createOptionsUpdatedTestData1() {
|
|
|
|
|
return {
|
|
|
|
|
profiles: [
|
|
|
|
|
{
|
|
|
|
|
name: 'Default',
|
|
|
|
|
options: createProfileOptionsUpdatedTestData1(),
|
|
|
|
|
conditionGroups: [
|
|
|
|
|
{
|
|
|
|
|
conditions: [
|
|
|
|
|
{
|
|
|
|
|
type: 'popupLevel',
|
|
|
|
|
operator: 'equal',
|
|
|
|
|
value: '1'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'popupLevel',
|
|
|
|
|
operator: 'notEqual',
|
|
|
|
|
value: '0'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'popupLevel',
|
|
|
|
|
operator: 'lessThan',
|
|
|
|
|
value: '3'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'popupLevel',
|
|
|
|
|
operator: 'greaterThan',
|
|
|
|
|
value: '0'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'popupLevel',
|
|
|
|
|
operator: 'lessThanOrEqual',
|
|
|
|
|
value: '2'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'popupLevel',
|
|
|
|
|
operator: 'greaterThanOrEqual',
|
|
|
|
|
value: '1'
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
conditions: [
|
|
|
|
|
{
|
|
|
|
|
type: 'url',
|
|
|
|
|
operator: 'matchDomain',
|
|
|
|
|
value: 'example.com'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'url',
|
|
|
|
|
operator: 'matchRegExp',
|
|
|
|
|
value: 'example\\.com'
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
conditions: [
|
|
|
|
|
{
|
|
|
|
|
type: 'modifierKeys',
|
|
|
|
|
operator: 'are',
|
|
|
|
|
value: 'ctrl, shift'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'modifierKeys',
|
|
|
|
|
operator: 'areNot',
|
|
|
|
|
value: 'alt, shift'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'modifierKeys',
|
|
|
|
|
operator: 'include',
|
|
|
|
|
value: 'alt'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
type: 'modifierKeys',
|
|
|
|
|
operator: 'notInclude',
|
|
|
|
|
value: 'ctrl'
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
],
|
|
|
|
|
profileCurrent: 0,
|
2021-05-16 19:24:38 +00:00
|
|
|
|
version: 12,
|
2020-09-20 15:33:12 +00:00
|
|
|
|
global: {
|
|
|
|
|
database: {
|
|
|
|
|
prefixWildcardsSupported: false
|
2021-03-15 02:51:48 +00:00
|
|
|
|
}
|
2020-09-20 15:33:12 +00:00
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async function testUpdate(extDir) {
|
|
|
|
|
const vm = createVM(extDir);
|
|
|
|
|
const [OptionsUtil] = vm.get(['OptionsUtil']);
|
|
|
|
|
const optionsUtil = new OptionsUtil();
|
|
|
|
|
await optionsUtil.prepare();
|
|
|
|
|
|
|
|
|
|
const options = createOptionsTestData1();
|
|
|
|
|
const optionsUpdated = clone(await optionsUtil.update(options));
|
|
|
|
|
const optionsExpected = createOptionsUpdatedTestData1();
|
|
|
|
|
assert.deepStrictEqual(optionsUpdated, optionsExpected);
|
|
|
|
|
}
|
|
|
|
|
|
2020-10-27 23:26:30 +00:00
|
|
|
|
async function testDefault(extDir) {
|
|
|
|
|
const data = [
|
|
|
|
|
(options) => options,
|
|
|
|
|
(options) => {
|
|
|
|
|
delete options.profiles[0].options.audio.autoPlay;
|
|
|
|
|
},
|
|
|
|
|
(options) => {
|
|
|
|
|
options.profiles[0].options.audio.autoPlay = void 0;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
const vm = createVM(extDir);
|
|
|
|
|
const [OptionsUtil] = vm.get(['OptionsUtil']);
|
|
|
|
|
const optionsUtil = new OptionsUtil();
|
|
|
|
|
await optionsUtil.prepare();
|
|
|
|
|
|
|
|
|
|
for (const modify of data) {
|
|
|
|
|
const options = optionsUtil.getDefault();
|
|
|
|
|
|
|
|
|
|
const optionsModified = clone(options);
|
|
|
|
|
modify(optionsModified);
|
|
|
|
|
|
|
|
|
|
const optionsUpdated = await optionsUtil.update(clone(optionsModified));
|
|
|
|
|
assert.deepStrictEqual(clone(optionsUpdated), clone(options));
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-09-20 15:33:12 +00:00
|
|
|
|
|
|
|
|
|
async function testFieldTemplatesUpdate(extDir) {
|
|
|
|
|
const vm = createVM(extDir);
|
2021-01-29 02:17:10 +00:00
|
|
|
|
const [OptionsUtil, TemplatePatcher] = vm.get(['OptionsUtil', 'TemplatePatcher']);
|
2020-09-20 15:33:12 +00:00
|
|
|
|
const optionsUtil = new OptionsUtil();
|
|
|
|
|
await optionsUtil.prepare();
|
|
|
|
|
|
2021-01-29 02:17:10 +00:00
|
|
|
|
const templatePatcher = new TemplatePatcher();
|
|
|
|
|
const loadDataFile = (fileName) => {
|
|
|
|
|
const content = fs.readFileSync(path.join(extDir, fileName), {encoding: 'utf8'});
|
|
|
|
|
return templatePatcher.parsePatch(content).addition;
|
|
|
|
|
};
|
2021-02-13 00:56:24 +00:00
|
|
|
|
const update2 = loadDataFile('data/templates/anki-field-templates-upgrade-v2.handlebars');
|
|
|
|
|
const update4 = loadDataFile('data/templates/anki-field-templates-upgrade-v4.handlebars');
|
|
|
|
|
const update6 = loadDataFile('data/templates/anki-field-templates-upgrade-v6.handlebars');
|
|
|
|
|
const update8 = loadDataFile('data/templates/anki-field-templates-upgrade-v8.handlebars');
|
2021-03-26 23:50:54 +00:00
|
|
|
|
const update10 = loadDataFile('data/templates/anki-field-templates-upgrade-v10.handlebars');
|
2021-05-18 00:18:37 +00:00
|
|
|
|
const update12 = loadDataFile('data/templates/anki-field-templates-upgrade-v12.handlebars');
|
2020-09-20 15:33:12 +00:00
|
|
|
|
|
|
|
|
|
const data = [
|
|
|
|
|
// Standard format
|
|
|
|
|
{
|
|
|
|
|
old: `
|
|
|
|
|
{{#*inline "character"}}
|
|
|
|
|
{{~definition.character~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{~> (lookup . "marker") ~}}`.trimStart(),
|
|
|
|
|
|
|
|
|
|
expected: `
|
|
|
|
|
{{#*inline "character"}}
|
|
|
|
|
{{~definition.character~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
${update2}
|
|
|
|
|
${update4}
|
2020-11-05 01:39:23 +00:00
|
|
|
|
${update6}
|
2021-01-16 20:29:42 +00:00
|
|
|
|
${update8}
|
2021-03-26 23:50:54 +00:00
|
|
|
|
${update10}
|
2021-05-18 00:18:37 +00:00
|
|
|
|
${update12}
|
2020-09-20 15:33:12 +00:00
|
|
|
|
{{~> (lookup . "marker") ~}}`.trimStart()
|
|
|
|
|
},
|
|
|
|
|
// Non-standard marker format
|
|
|
|
|
{
|
|
|
|
|
old: `
|
|
|
|
|
{{#*inline "character"}}
|
|
|
|
|
{{~definition.character~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{~> (lookup . "marker2") ~}}`.trimStart(),
|
|
|
|
|
|
|
|
|
|
expected: `
|
|
|
|
|
{{#*inline "character"}}
|
|
|
|
|
{{~definition.character~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{~> (lookup . "marker2") ~}}
|
|
|
|
|
${update2}
|
2020-11-05 01:39:23 +00:00
|
|
|
|
${update4}
|
2021-01-16 20:29:42 +00:00
|
|
|
|
${update6}
|
2021-03-26 23:50:54 +00:00
|
|
|
|
${update8}
|
2021-05-18 00:18:37 +00:00
|
|
|
|
${update10}
|
|
|
|
|
${update12}`.trimStart()
|
2020-09-20 15:33:12 +00:00
|
|
|
|
},
|
|
|
|
|
// Empty test
|
|
|
|
|
{
|
|
|
|
|
old: `
|
|
|
|
|
{{~> (lookup . "marker") ~}}`.trimStart(),
|
|
|
|
|
|
|
|
|
|
expected: `
|
|
|
|
|
${update2}
|
|
|
|
|
${update4}
|
2020-11-05 01:39:23 +00:00
|
|
|
|
${update6}
|
2021-01-16 20:29:42 +00:00
|
|
|
|
${update8}
|
2021-03-26 23:50:54 +00:00
|
|
|
|
${update10}
|
2021-05-18 00:18:37 +00:00
|
|
|
|
${update12}
|
2020-09-20 15:33:12 +00:00
|
|
|
|
{{~> (lookup . "marker") ~}}`.trimStart()
|
2020-11-13 01:34:11 +00:00
|
|
|
|
},
|
|
|
|
|
// Definition tags update
|
|
|
|
|
{
|
|
|
|
|
old: `
|
|
|
|
|
{{#*inline "glossary-single"}}
|
|
|
|
|
{{~#unless brief~}}
|
|
|
|
|
{{~#if definitionTags~}}<i>({{#each definitionTags}}{{name}}{{#unless @last}}, {{/unless}}{{/each}})</i> {{/if~}}
|
|
|
|
|
{{~#if only~}}({{#each only}}{{{.}}}{{#unless @last}}, {{/unless}}{{/each}} only) {{/if~}}
|
|
|
|
|
{{~/unless~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{#*inline "glossary-single2"}}
|
|
|
|
|
{{~#unless brief~}}
|
|
|
|
|
{{~#if definitionTags~}}<i>({{#each definitionTags}}{{name}}{{#unless @last}}, {{/unless}}{{/each}})</i> {{/if~}}
|
|
|
|
|
{{~#if only~}}({{#each only}}{{{.}}}{{#unless @last}}, {{/unless}}{{/each}} only) {{/if~}}
|
|
|
|
|
{{~/unless~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{#*inline "glossary"}}
|
|
|
|
|
{{~> glossary-single definition brief=brief compactGlossaries=compactGlossaries~}}
|
|
|
|
|
{{~> glossary-single definition brief=brief compactGlossaries=../compactGlossaries~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{~> (lookup . "marker") ~}}
|
|
|
|
|
`.trimStart(),
|
|
|
|
|
|
|
|
|
|
expected: `
|
|
|
|
|
{{#*inline "glossary-single"}}
|
|
|
|
|
{{~#unless brief~}}
|
|
|
|
|
{{~#scope~}}
|
|
|
|
|
{{~#set "any" false}}{{/set~}}
|
|
|
|
|
{{~#if definitionTags~}}{{#each definitionTags~}}
|
|
|
|
|
{{~#if (op "||" (op "!" ../data.compactTags) (op "!" redundant))~}}
|
|
|
|
|
{{~#if (get "any")}}, {{else}}<i>({{/if~}}
|
|
|
|
|
{{name}}
|
|
|
|
|
{{~#set "any" true}}{{/set~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~/each~}}
|
|
|
|
|
{{~#if (get "any")}})</i> {{/if~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~/scope~}}
|
|
|
|
|
{{~#if only~}}({{#each only}}{{{.}}}{{#unless @last}}, {{/unless}}{{/each}} only) {{/if~}}
|
|
|
|
|
{{~/unless~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{#*inline "glossary-single2"}}
|
|
|
|
|
{{~#unless brief~}}
|
|
|
|
|
{{~#scope~}}
|
|
|
|
|
{{~#set "any" false}}{{/set~}}
|
|
|
|
|
{{~#if definitionTags~}}{{#each definitionTags~}}
|
|
|
|
|
{{~#if (op "||" (op "!" ../data.compactTags) (op "!" redundant))~}}
|
|
|
|
|
{{~#if (get "any")}}, {{else}}<i>({{/if~}}
|
|
|
|
|
{{name}}
|
|
|
|
|
{{~#set "any" true}}{{/set~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~/each~}}
|
|
|
|
|
{{~#if (get "any")}})</i> {{/if~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~/scope~}}
|
|
|
|
|
{{~#if only~}}({{#each only}}{{{.}}}{{#unless @last}}, {{/unless}}{{/each}} only) {{/if~}}
|
|
|
|
|
{{~/unless~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{#*inline "glossary"}}
|
|
|
|
|
{{~> glossary-single definition brief=brief compactGlossaries=compactGlossaries data=.~}}
|
|
|
|
|
{{~> glossary-single definition brief=brief compactGlossaries=../compactGlossaries data=../.~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
${update2}
|
|
|
|
|
${update4}
|
|
|
|
|
${update6}
|
2021-01-16 20:29:42 +00:00
|
|
|
|
${update8}
|
2021-03-26 23:50:54 +00:00
|
|
|
|
${update10}
|
2021-05-18 00:18:37 +00:00
|
|
|
|
${update12}
|
2020-11-13 01:34:11 +00:00
|
|
|
|
{{~> (lookup . "marker") ~}}
|
|
|
|
|
`.trimStart()
|
2021-01-29 02:17:10 +00:00
|
|
|
|
},
|
|
|
|
|
// glossary and glossary-brief update
|
|
|
|
|
{
|
|
|
|
|
oldVersion: 7,
|
|
|
|
|
old: `
|
|
|
|
|
{{#*inline "glossary-single"}}
|
|
|
|
|
{{~#unless brief~}}
|
|
|
|
|
{{~#scope~}}
|
|
|
|
|
{{~#set "any" false}}{{/set~}}
|
|
|
|
|
{{~#if definitionTags~}}{{#each definitionTags~}}
|
|
|
|
|
{{~#if (op "||" (op "!" ../data.compactTags) (op "!" redundant))~}}
|
|
|
|
|
{{~#if (get "any")}}, {{else}}<i>({{/if~}}
|
|
|
|
|
{{name}}
|
|
|
|
|
{{~#set "any" true}}{{/set~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~/each~}}
|
|
|
|
|
{{~#if (get "any")}})</i> {{/if~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~/scope~}}
|
|
|
|
|
{{~#if only~}}({{#each only}}{{{.}}}{{#unless @last}}, {{/unless}}{{/each}} only) {{/if~}}
|
|
|
|
|
{{~/unless~}}
|
|
|
|
|
{{~#if glossary.[1]~}}
|
|
|
|
|
{{~#if compactGlossaries~}}
|
|
|
|
|
{{#each glossary}}{{#multiLine}}{{.}}{{/multiLine}}{{#unless @last}} | {{/unless}}{{/each}}
|
|
|
|
|
{{~else~}}
|
|
|
|
|
<ul>{{#each glossary}}<li>{{#multiLine}}{{.}}{{/multiLine}}</li>{{/each}}</ul>
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~else~}}
|
|
|
|
|
{{~#multiLine}}{{glossary.[0]}}{{/multiLine~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{#*inline "character"}}
|
|
|
|
|
{{~definition.character~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{#*inline "glossary"}}
|
|
|
|
|
<div style="text-align: left;">
|
|
|
|
|
{{~#if modeKanji~}}
|
|
|
|
|
{{~#if definition.glossary.[1]~}}
|
|
|
|
|
<ol>{{#each definition.glossary}}<li>{{.}}</li>{{/each}}</ol>
|
|
|
|
|
{{~else~}}
|
|
|
|
|
{{definition.glossary.[0]}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~else~}}
|
|
|
|
|
{{~#if group~}}
|
|
|
|
|
{{~#if definition.definitions.[1]~}}
|
|
|
|
|
<ol>{{#each definition.definitions}}<li>{{> glossary-single brief=../brief compactGlossaries=../compactGlossaries data=../.}}</li>{{/each}}</ol>
|
|
|
|
|
{{~else~}}
|
|
|
|
|
{{~> glossary-single definition.definitions.[0] brief=brief compactGlossaries=compactGlossaries data=.~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~else if merge~}}
|
|
|
|
|
{{~#if definition.definitions.[1]~}}
|
|
|
|
|
<ol>{{#each definition.definitions}}<li>{{> glossary-single brief=../brief compactGlossaries=../compactGlossaries data=../.}}</li>{{/each}}</ol>
|
|
|
|
|
{{~else~}}
|
|
|
|
|
{{~> glossary-single definition.definitions.[0] brief=brief compactGlossaries=compactGlossaries data=.~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~else~}}
|
|
|
|
|
{{~> glossary-single definition brief=brief compactGlossaries=compactGlossaries data=.~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
</div>
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{#*inline "glossary-brief"}}
|
|
|
|
|
{{~> glossary brief=true ~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{~> (lookup . "marker") ~}}`.trimStart(),
|
|
|
|
|
|
|
|
|
|
expected: `
|
|
|
|
|
{{#*inline "glossary-single"}}
|
|
|
|
|
{{~#unless brief~}}
|
|
|
|
|
{{~#scope~}}
|
|
|
|
|
{{~#set "any" false}}{{/set~}}
|
|
|
|
|
{{~#each definitionTags~}}
|
|
|
|
|
{{~#if (op "||" (op "!" @root.compactTags) (op "!" redundant))~}}
|
|
|
|
|
{{~#if (get "any")}}, {{else}}<i>({{/if~}}
|
|
|
|
|
{{name}}
|
|
|
|
|
{{~#set "any" true}}{{/set~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~/each~}}
|
2021-01-29 02:33:30 +00:00
|
|
|
|
{{~#unless noDictionaryTag~}}
|
|
|
|
|
{{~#if (op "||" (op "!" @root.compactTags) (op "!==" dictionary (get "previousDictionary")))~}}
|
|
|
|
|
{{~#if (get "any")}}, {{else}}<i>({{/if~}}
|
|
|
|
|
{{dictionary}}
|
|
|
|
|
{{~#set "any" true}}{{/set~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~/unless~}}
|
2021-01-29 02:17:10 +00:00
|
|
|
|
{{~#if (get "any")}})</i> {{/if~}}
|
|
|
|
|
{{~/scope~}}
|
|
|
|
|
{{~#if only~}}({{#each only}}{{.}}{{#unless @last}}, {{/unless}}{{/each}} only) {{/if~}}
|
|
|
|
|
{{~/unless~}}
|
|
|
|
|
{{~#if (op "<=" glossary.length 1)~}}
|
|
|
|
|
{{#each glossary}}{{#multiLine}}{{.}}{{/multiLine}}{{/each}}
|
|
|
|
|
{{~else if @root.compactGlossaries~}}
|
|
|
|
|
{{#each glossary}}{{#multiLine}}{{.}}{{/multiLine}}{{#unless @last}} | {{/unless}}{{/each}}
|
|
|
|
|
{{~else~}}
|
|
|
|
|
<ul>{{#each glossary}}<li>{{#multiLine}}{{.}}{{/multiLine}}</li>{{/each}}</ul>
|
|
|
|
|
{{~/if~}}
|
2021-01-29 02:33:30 +00:00
|
|
|
|
{{~#set "previousDictionary" dictionary~}}{{~/set~}}
|
2021-01-29 02:17:10 +00:00
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{#*inline "character"}}
|
|
|
|
|
{{~definition.character~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
{{~#*inline "glossary"~}}
|
|
|
|
|
<div style="text-align: left;">
|
|
|
|
|
{{~#scope~}}
|
|
|
|
|
{{~#if (op "===" definition.type "term")~}}
|
2021-01-29 02:33:30 +00:00
|
|
|
|
{{~> glossary-single definition brief=brief noDictionaryTag=noDictionaryTag ~}}
|
2021-01-29 02:17:10 +00:00
|
|
|
|
{{~else if (op "||" (op "===" definition.type "termGrouped") (op "===" definition.type "termMerged"))~}}
|
|
|
|
|
{{~#if (op ">" definition.definitions.length 1)~}}
|
2021-01-29 02:33:30 +00:00
|
|
|
|
<ol>{{~#each definition.definitions~}}<li>{{~> glossary-single . brief=../brief noDictionaryTag=../noDictionaryTag ~}}</li>{{~/each~}}</ol>
|
2021-01-29 02:17:10 +00:00
|
|
|
|
{{~else~}}
|
2021-01-29 02:33:30 +00:00
|
|
|
|
{{~#each definition.definitions~}}{{~> glossary-single . brief=../brief noDictionaryTag=../noDictionaryTag ~}}{{~/each~}}
|
2021-01-29 02:17:10 +00:00
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~else if (op "===" definition.type "kanji")~}}
|
|
|
|
|
{{~#if (op ">" definition.glossary.length 1)~}}
|
|
|
|
|
<ol>{{#each definition.glossary}}<li>{{.}}</li>{{/each}}</ol>
|
|
|
|
|
{{~else~}}
|
|
|
|
|
{{~#each definition.glossary~}}{{.}}{{~/each~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~/if~}}
|
|
|
|
|
{{~/scope~}}
|
|
|
|
|
</div>
|
|
|
|
|
{{~/inline~}}
|
|
|
|
|
|
2021-01-29 02:33:30 +00:00
|
|
|
|
{{#*inline "glossary-no-dictionary"}}
|
|
|
|
|
{{~> glossary noDictionaryTag=true ~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
2021-01-29 02:17:10 +00:00
|
|
|
|
{{#*inline "glossary-brief"}}
|
|
|
|
|
{{~> glossary brief=true ~}}
|
|
|
|
|
{{/inline}}
|
|
|
|
|
|
|
|
|
|
${update8}
|
2021-03-26 23:50:54 +00:00
|
|
|
|
${update10}
|
2021-05-18 00:18:37 +00:00
|
|
|
|
${update12}
|
2021-01-29 02:17:10 +00:00
|
|
|
|
{{~> (lookup . "marker") ~}}`.trimStart()
|
2020-09-20 15:33:12 +00:00
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
2021-01-29 02:17:10 +00:00
|
|
|
|
for (const {old, expected, oldVersion} of data) {
|
2020-09-20 15:33:12 +00:00
|
|
|
|
const options = createOptionsTestData1();
|
|
|
|
|
options.profiles[0].options.anki.fieldTemplates = old;
|
2021-01-29 02:17:10 +00:00
|
|
|
|
if (typeof oldVersion === 'number') {
|
|
|
|
|
options.version = oldVersion;
|
|
|
|
|
}
|
|
|
|
|
|
2020-09-20 15:33:12 +00:00
|
|
|
|
const optionsUpdated = clone(await optionsUtil.update(options));
|
|
|
|
|
const fieldTemplatesActual = optionsUpdated.profiles[0].options.anki.fieldTemplates;
|
|
|
|
|
assert.deepStrictEqual(fieldTemplatesActual, expected);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async function main() {
|
|
|
|
|
const extDir = path.join(__dirname, '..', 'ext');
|
|
|
|
|
await testUpdate(extDir);
|
2020-10-27 23:26:30 +00:00
|
|
|
|
await testDefault(extDir);
|
2020-09-20 15:33:12 +00:00
|
|
|
|
await testFieldTemplatesUpdate(extDir);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2020-11-07 16:34:14 +00:00
|
|
|
|
if (require.main === module) { testMain(main); }
|