Я пытаюсь выполнить простейшее слияние данных с InDesign Server и продолжать сбой.Я начинаю сервер с ./InDesignServer -port 18383
, запускается без проблем.Я вызываю скрипт с ./sampleclient ./scripts/test.jsx
.jsx выглядит так:
var source = File("/Users/me/Desktop/InDesign Server/example/example.indd")
var destination = File("/Users/me/Desktop/InDesign Server/example/example.pdf")
var sourceData = File("/Users/me/Desktop/InDesign Server/example/example.csv")
var doc = app.open(source);
doc.dataMergeProperties.selectDataSource(sourceData);
doc.dataMergeProperties.dataMergePreferences.recordNumber = 1;
doc.dataMergeProperties.mergeRecords(); // <-- Crashes here
var myPDFExportPreset = app.pdfExportPresets.item(0);
app.documents.item(0).exportFile(ExportFormat.pdfType, destination, false, myPDFExportPreset);
app.documents.item(0).close(SaveOptions.no);
doc.close(SaveOptions.no);
InDesign Server отвечает:
Tue Sep 18 09:48:21 2018 INFO [javascript] Executing Script
./InDesignServer: line 13: 30363 Segmentation fault: 11 "$installed_name" "$@"
И вылетает.Этот скрипт прекрасно работает в InDesign CC Desktop.Сбой сервера при вызове .mergeRecords ().Есть идеи, почему?
Редактировать: я изменил код на 1) Нет пробелов в пути к файлу 2) Проверьте, все ли мои объекты существуют перед выполнением слияния.
var source = File("/Users/me/Desktop/example/example.indd");
var destination = File("/Users/me/Desktop/example/example.pdf");
var sourceData = File("/Users/me/Desktop/example/example.csv");
var doc = app.open(source);
doc.dataMergeProperties.selectDataSource(sourceData);
if (source.exists && destination.exists && sourceData.exists) {
try {
app.consoleout("Performing merge...");
doc.dataMergeProperties.mergeRecords(); // <-- Crashes here
} catch (err) {
app.consoleout(err);
}
} else {
app.consoleout("Something doesn't exist...");
}
В нем записывается «Выполнение слияния ...», поэтому пути к моим файлам фактически указывают на файлы, которые существуют.Более того, он полон при сбоях и не сообщает об ошибках.
Редактировать 2: Следует отметить, что это ошибка, которую окно Terminal, которое запускало sampleclient, получает от IDS: Error -1 fault: SOAP-ENV:Client [no subcode]
"End of file or no input: Operation interrupted or timed out"
Detail: [no detail]