cascade / static /j2s /JV /OutputManager.js
bobbypaton
Initial CASCADE HF Space deployment
233f6d4
Clazz.declarePackage ("JV");
Clazz.load (null, "JV.OutputManager", ["java.lang.Boolean", "java.util.Date", "$.Hashtable", "$.Map", "JU.AU", "$.Lst", "$.OC", "$.PT", "$.SB", "J.api.Interface", "J.i18n.GT", "JU.Logger", "JV.FileManager", "$.JC", "$.Viewer"], function () {
c$ = Clazz.decorateAsClass (function () {
this.vwr = null;
this.privateKey = 0;
Clazz.instantialize (this, arguments);
}, JV, "OutputManager");
Clazz.defineMethod (c$, "setViewer",
function (vwr, privateKey) {
this.vwr = vwr;
this.privateKey = privateKey;
return this;
}, "JV.Viewer,~N");
Clazz.defineMethod (c$, "writeToOutputChannel",
function (params) {
var type = params.get ("type");
var fileName = params.get ("fileName");
var text = params.get ("text");
var bytes = params.get ("bytes");
var quality = JV.OutputManager.getInt (params, "quality", -2147483648);
var out = params.get ("outputChannel");
var closeStream = (out == null);
var len = -1;
var ret = null;
try {
if (!this.vwr.checkPrivateKey (this.privateKey)) return "ERROR: SECURITY";
if (bytes != null) {
if (out == null) out = this.openOutputChannel (this.privateKey, fileName, false, false);
out.write (bytes, 0, bytes.length);
} else if (text != null && !type.equals ("ZIPDATA") && !type.equals ("BINARY")) {
if (out == null) out = this.openOutputChannel (this.privateKey, fileName, true, false);
out.append (text);
} else {
var errMsg = this.getOrSaveImage (params);
if (errMsg != null) return errMsg;
len = (params.get ("byteCount")).intValue ();
}} catch (exc) {
if (Clazz.exceptionOf (exc, Exception)) {
JU.Logger.errorEx ("IO Exception", exc);
return exc.toString ();
} else {
throw exc;
}
} finally {
if (out != null) {
if (closeStream) ret = out.closeChannel ();
len = out.getByteCount ();
}}
var pt = fileName.indexOf ("?POST?");
if (pt >= 0) fileName = fileName.substring (0, pt);
return (len < 0 ? "Creation of " + fileName + " failed: " + (ret == null ? this.vwr.getErrorMessageUn () : ret) : "OK " + type + " " + (len > 0 ? len + " " : "") + fileName + (quality == -2147483648 ? "" : "; quality=" + quality));
}, "java.util.Map");
Clazz.defineMethod (c$, "getOrSaveImage",
function (params) {
var bytes = null;
var errMsg = null;
var type = (params.get ("type")).toUpperCase ();
var fileName = params.get ("fileName");
var scripts = params.get ("scripts");
var objImage = params.get ("image");
var rgbbuf = params.get ("rgbbuf");
var out = params.get ("outputChannel");
var asBytes = (out == null && fileName == null);
var closeChannel = (out == null && fileName != null);
var releaseImage = (objImage == null);
var image = (type.equals ("BINARY") || type.equals ("ZIPDATA") ? "" : rgbbuf != null ? rgbbuf : objImage != null ? objImage : this.vwr.getScreenImageBuffer (null, true));
var isOK = false;
try {
if (image == null) return errMsg = this.vwr.getErrorMessage ();
if (fileName != null && fileName.startsWith ("\1")) {
isOK = true;
var info = new java.util.Hashtable ();
info.put ("_IMAGE_", image);
this.vwr.fm.loadImage (info, fileName, false);
return errMsg = "OK - viewing " + fileName.substring (1);
}var isPngj = type.equals ("PNGJ");
if (!isPngj) {
if (out == null && (out = this.openOutputChannel (this.privateKey, fileName, false, false)) == null) return errMsg = "ERROR: canceled";
fileName = out.getFileName ();
}var comment = null;
var stateData = null;
params.put ("date", this.vwr.apiPlatform.getDateFormat ("8601"));
if (type.startsWith ("JP")) {
type = JU.PT.rep (type, "E", "");
if (type.equals ("JPG64")) {
params.put ("outputChannelTemp", this.getOutputChannel (null, null));
comment = "";
} else {
comment = (!asBytes ? this.getWrappedState (null, null, image, null) : "");
}params.put ("jpgAppTag", " #Jmol...\u0000");
} else if (type.equals ("PDF")) {
comment = "";
} else if (type.startsWith ("PNG")) {
comment = "";
if (isPngj) {
var outTemp = this.getOutputChannel (null, null);
this.getWrappedState (fileName, scripts, image, outTemp);
stateData = outTemp.toByteArray ();
if (out == null && (out = this.openOutputChannel (this.privateKey, fileName, false, false)) == null) return errMsg = "ERROR: canceled";
} else if (rgbbuf == null && !asBytes && !params.containsKey ("captureMode")) {
stateData = (this.getWrappedState (null, scripts, image, null)).getBytes ();
}if (stateData != null) {
params.put ("pngAppData", stateData);
params.put ("pngAppPrefix", "Jmol Type");
}}if (type.equals ("PNGT") || type.equals ("GIFT")) params.put ("transparentColor", Integer.$valueOf (this.vwr.getBackgroundArgb ()));
if (type.length == 4) type = type.substring (0, 3);
if (comment != null) params.put ("comment", comment.length == 0 ? JV.Viewer.getJmolVersion () : comment);
var errRet = new Array (1);
isOK = this.createTheImage (image, type, out, params, errRet);
if (closeChannel) out.closeChannel ();
if (isOK) {
if (params.containsKey ("captureMsg") && !params.containsKey ("captureSilent")) this.vwr.prompt (params.get ("captureMsg"), "OK", null, true);
if (asBytes) bytes = out.toByteArray ();
else if (params.containsKey ("captureByteCount")) errMsg = "OK: " + params.get ("captureByteCount").toString () + " bytes";
} else {
errMsg = errRet[0];
}} finally {
if (releaseImage) this.vwr.releaseScreenImage ();
if (bytes != null || out != null) params.put ("byteCount", Integer.$valueOf (bytes != null ? bytes.length : isOK ? out.getByteCount () : -1));
if (objImage != null) {
return fileName;
}}
return (errMsg == null ? bytes : errMsg);
}, "java.util.Map");
Clazz.defineMethod (c$, "getWrappedState",
function (pngjName, scripts, objImage, pgjOut) {
var width = this.vwr.apiPlatform.getImageWidth (objImage);
var height = this.vwr.apiPlatform.getImageHeight (objImage);
if (width > 0 && !this.vwr.g.imageState && pgjOut == null || !this.vwr.g.preserveState) return "";
var s = this.vwr.getStateInfo3 (null, width, height);
if (pgjOut != null) {
return this.createZipSet (s, scripts, true, pgjOut, pngjName);
}try {
s = JV.JC.embedScript (JV.FileManager.setScriptFileReferences (s, ".", null, null));
} catch (e) {
JU.Logger.error ("state could not be saved: " + e.toString ());
s = "Jmol " + JV.Viewer.getJmolVersion ();
}
return s;
}, "~S,~A,~O,JU.OC");
Clazz.defineMethod (c$, "createTheImage",
function (objImage, type, out, params, errRet) {
type = type.substring (0, 1) + type.substring (1).toLowerCase ();
var isZipData = type.equals ("Zipdata");
if (isZipData || type.equals ("Binary")) {
var v = params.get ("imageData");
if (v.size () >= 2 && v.get (0).equals ("_IMAGE_")) {
if (isZipData) {
errRet[0] = this.writeZipFile (out, v, "OK JMOL", null);
return true;
}objImage = null;
v.removeItemAt (0);
v.removeItemAt (0);
params.put ("pngImgData", v.removeItemAt (0));
var oz = this.getOutputChannel (null, null);
errRet[0] = this.writeZipFile (oz, v, "OK JMOL", null);
params.put ("type", "PNGJ");
type = "Png";
params.put ("pngAppPrefix", "Jmol Type");
params.put ("pngAppData", oz.toByteArray ());
} else if (v.size () == 1) {
var b = v.removeItemAt (0);
out.write (b, 0, b.length);
return true;
} else {
errRet[0] = this.writeZipFile (out, v, "OK JMOL", null);
return true;
}}var ie = J.api.Interface.getInterface ("javajs.img." + type + "Encoder", this.vwr, "file");
if (ie == null) {
errRet[0] = "Image encoder type " + type + " not available";
return false;
}var doClose = true;
try {
if (type.equals ("Gif") && this.vwr.getBoolean (603979962)) params.put ("reducedColors", Boolean.TRUE);
var w = objImage == null ? -1 : JU.AU.isAI (objImage) ? (params.get ("width")).intValue () : this.vwr.apiPlatform.getImageWidth (objImage);
var h = objImage == null ? -1 : JU.AU.isAI (objImage) ? (params.get ("height")).intValue () : this.vwr.apiPlatform.getImageHeight (objImage);
params.put ("imageWidth", Integer.$valueOf (w));
params.put ("imageHeight", Integer.$valueOf (h));
var pixels = this.encodeImage (w, h, objImage);
if (pixels != null) params.put ("imagePixels", pixels);
params.put ("logging", Boolean.$valueOf (JU.Logger.debugging));
doClose = ie.createImage (type, out, params);
} catch (e) {
if (Clazz.exceptionOf (e, Exception)) {
errRet[0] = e.toString ();
out.cancel ();
doClose = true;
} else {
throw e;
}
} finally {
if (doClose) out.closeChannel ();
}
return (errRet[0] == null);
}, "~O,~S,JU.OC,java.util.Map,~A");
Clazz.defineMethod (c$, "encodeImage",
function (width, height, objImage) {
if (width < 0) return null;
var pixels;
if (JU.AU.isAI (objImage)) {
pixels = objImage;
} else {
{
pixels = null;
}pixels = this.vwr.apiPlatform.grabPixels (objImage, width, height, pixels, 0, height);
}return pixels;
}, "~N,~N,~O");
Clazz.defineMethod (c$, "outputToFile",
function (params) {
return this.handleOutputToFile (params, true);
}, "java.util.Map");
Clazz.defineMethod (c$, "getOutputChannel",
function (fileName, fullPath) {
if (!this.vwr.haveAccess (JV.Viewer.ACCESS.ALL)) return null;
var isCache = (fileName != null && fileName.startsWith ("cache://"));
if (fileName != null && !isCache) {
fileName = this.getOutputFileNameFromDialog (fileName, -2147483648, null);
if (fileName == null) return null;
}if (fullPath != null) fullPath[0] = fileName;
var localName = (JU.OC.isLocal (fileName) || isCache ? fileName : null);
try {
return this.openOutputChannel (this.privateKey, localName, false, false);
} catch (e) {
if (Clazz.exceptionOf (e, java.io.IOException)) {
JU.Logger.info (e.toString ());
return null;
} else {
throw e;
}
}
}, "~S,~A");
Clazz.defineMethod (c$, "processWriteOrCapture",
function (params) {
var fileName = params.get ("fileName");
if (fileName == null) return this.vwr.clipImageOrPasteText (params.get ("text"));
var bsFrames = params.get ("bsFrames");
var nVibes = JV.OutputManager.getInt (params, "nVibes", 0);
return (bsFrames != null || nVibes != 0 ? this.processMultiFrameOutput (fileName, bsFrames, nVibes, params) : this.handleOutputToFile (params, true));
}, "java.util.Map");
c$.getInt = Clazz.defineMethod (c$, "getInt",
function (params, key, def) {
var p = params.get (key);
return (p == null ? def : p.intValue ());
}, "java.util.Map,~S,~N");
Clazz.defineMethod (c$, "processMultiFrameOutput",
function (fileName, bsFrames, nVibes, params) {
var info = "";
var n = 0;
var quality = JV.OutputManager.getInt (params, "quality", -1);
fileName = this.setFullPath (params, this.getOutputFileNameFromDialog (fileName, quality, null));
if (fileName == null) return null;
var rootExt = new Array (2);
JV.OutputManager.getRootExt (fileName, rootExt, 0);
var sb = new JU.SB ();
if (bsFrames == null) {
this.vwr.tm.vibrationOn = true;
sb = new JU.SB ();
for (var i = 0; i < nVibes; i++) {
for (var j = 0; j < 20; j++) {
this.vwr.tm.setVibrationT (j / 20 + 0.2501);
if (!this.writeFrame (++n, rootExt, params, sb)) return "ERROR WRITING FILE SET: \n" + info;
}
}
this.vwr.tm.setVibrationPeriod (0);
} else {
for (var i = bsFrames.nextSetBit (0); i >= 0; i = bsFrames.nextSetBit (i + 1)) {
this.vwr.setCurrentModelIndex (i);
if (!this.writeFrame (++n, rootExt, params, sb)) return "ERROR WRITING FILE SET: \n" + info;
}
}if (info.length == 0) info = "OK\n";
return info + "\n" + n + " files created";
}, "~S,JU.BS,~N,java.util.Map");
c$.getRootExt = Clazz.defineMethod (c$, "getRootExt",
function (fileName, rootExt, n) {
if (fileName == null) {
fileName = "0000" + n;
return rootExt[0] + fileName.substring (fileName.length - 4) + rootExt[1];
}var ptDot = fileName.lastIndexOf (".");
if (ptDot < 0) ptDot = fileName.length;
var froot = fileName.substring (0, ptDot);
if (froot.endsWith ("0")) froot = JU.PT.trim (froot, "0");
rootExt[0] = froot;
rootExt[1] = fileName.substring (ptDot);
return rootExt;
}, "~S,~A,~N");
Clazz.defineMethod (c$, "setFullPath",
function (params, fileName) {
var fullPath = params.get ("fullPath");
if (fullPath != null) fullPath[0] = fileName;
if (fileName == null) return null;
params.put ("fileName", fileName);
return fileName;
}, "java.util.Map,~S");
Clazz.defineMethod (c$, "getOutputFromExport",
function (params) {
var width = JV.OutputManager.getInt (params, "width", 0);
var height = JV.OutputManager.getInt (params, "height", 0);
var fileName = params.get ("fileName");
if (fileName != null) {
fileName = this.setFullPath (params, this.getOutputFileNameFromDialog (fileName, -2147483648, null));
if (fileName == null) return null;
}this.vwr.mustRender = true;
var saveWidth = this.vwr.dimScreen.width;
var saveHeight = this.vwr.dimScreen.height;
this.vwr.resizeImage (width, height, true, true, false);
this.vwr.setModelVisibility ();
var data = this.vwr.rm.renderExport (this.vwr.gdata, this.vwr.ms, params);
this.vwr.resizeImage (saveWidth, saveHeight, true, true, true);
return data;
}, "java.util.Map");
Clazz.defineMethod (c$, "getImageAsBytes",
function (type, width, height, quality, errMsg) {
var saveWidth = this.vwr.dimScreen.width;
var saveHeight = this.vwr.dimScreen.height;
this.vwr.mustRender = true;
this.vwr.resizeImage (width, height, true, false, false);
this.vwr.setModelVisibility ();
this.vwr.creatingImage = true;
var bytes = null;
try {
var params = new java.util.Hashtable ();
params.put ("type", type);
if (quality > 0) params.put ("quality", Integer.$valueOf (quality));
var bytesOrError = this.getOrSaveImage (params);
if (Clazz.instanceOf (bytesOrError, String)) errMsg[0] = bytesOrError;
else bytes = bytesOrError;
} catch (e$$) {
if (Clazz.exceptionOf (e$$, Exception)) {
var e = e$$;
{
errMsg[0] = e.toString ();
this.vwr.setErrorMessage ("Error creating image: " + e, null);
}
} else if (Clazz.exceptionOf (e$$, Error)) {
var er = e$$;
{
this.vwr.handleError (er, false);
this.vwr.setErrorMessage ("Error creating image: " + er, null);
errMsg[0] = this.vwr.getErrorMessage ();
}
} else {
throw e$$;
}
}
this.vwr.creatingImage = false;
this.vwr.resizeImage (saveWidth, saveHeight, true, false, true);
return bytes;
}, "~S,~N,~N,~N,~A");
Clazz.defineMethod (c$, "writeFileData",
function (fileName, type, modelIndex, plotParameters) {
var fullPath = new Array (1);
var out = this.getOutputChannel (fileName, fullPath);
if (out == null) return "";
fileName = fullPath[0];
var pathName = (type.equals ("FILE") ? this.vwr.fm.getFullPathName (false) : null);
var getCurrentFile = (pathName != null && (pathName.equals ("string") || pathName.equals ("String[]") || pathName.equals ("JSNode")));
var asBytes = (pathName != null && !getCurrentFile);
if (asBytes) {
pathName = this.vwr.getModelSetPathName ();
if (pathName == null) return null;
}out.setType (type);
var msg = (type.startsWith ("PDB") ? this.vwr.getPdbAtomData (null, out, false, false) : type.startsWith ("PLOT") ? this.vwr.getPdbData (modelIndex, type.substring (5), null, plotParameters, out, true) : getCurrentFile ? out.append (this.vwr.getCurrentFileAsString ("write")).toString () : this.vwr.fm.getFileAsBytes (pathName, out));
out.closeChannel ();
if (msg != null) msg = "OK " + msg + " " + fileName;
return msg;
}, "~S,~S,~N,~A");
Clazz.defineMethod (c$, "writeFrame",
function (n, rootExt, params, sb) {
var fileName = JV.OutputManager.getRootExt (null, rootExt, n);
fileName = this.setFullPath (params, fileName);
if (fileName == null) return false;
var msg = this.handleOutputToFile (params, false);
this.vwr.scriptEcho (msg);
sb.append (msg).append ("\n");
return msg.startsWith ("OK");
}, "~N,~A,java.util.Map,JU.SB");
Clazz.defineMethod (c$, "getOutputFileNameFromDialog",
function (fileName, quality, params) {
if (fileName == null || this.vwr.$isKiosk) return null;
var useDialog = fileName.startsWith ("?");
if (useDialog) fileName = fileName.substring (1);
useDialog = new Boolean (useDialog | (this.vwr.isApplet && (fileName.indexOf ("http:") < 0))).valueOf ();
fileName = JV.FileManager.getLocalPathForWritingFile (this.vwr, fileName);
if (useDialog) fileName = this.vwr.dialogAsk (quality == -2147483648 ? "Save" : "Save Image", fileName, params);
return fileName;
}, "~S,~N,java.util.Map");
Clazz.defineMethod (c$, "handleOutputToFile",
function (params, doCheck) {
var fileName = params.get ("fileName");
var out = params.get ("outputChannel");
if (fileName == null && out == null) return null;
var sret = null;
var type = params.get ("type");
var text = params.get ("text");
var width = JV.OutputManager.getInt (params, "width", 0);
var height = JV.OutputManager.getInt (params, "height", 0);
var saveWidth = 0;
var saveHeight = 0;
var quality = JV.OutputManager.getInt (params, "quality", -2147483648);
var captureMode = params.get ("captureMode");
var localName = null;
if (captureMode != null && !this.vwr.allowCapture ()) return "ERROR: Cannot capture on this platform.";
var mustRender = (quality != -2147483648);
if (captureMode != null) {
doCheck = false;
mustRender = false;
}if (out == null) {
if (!fileName.startsWith ("\1")) {
if (doCheck) fileName = this.getOutputFileNameFromDialog (fileName, quality, params);
fileName = this.setFullPath (params, fileName);
}if (fileName == null) return null;
params.put ("fileName", fileName);
if (JU.OC.isLocal (fileName)) localName = fileName;
saveWidth = this.vwr.dimScreen.width;
saveHeight = this.vwr.dimScreen.height;
this.vwr.creatingImage = true;
if (mustRender) {
this.vwr.mustRender = true;
this.vwr.resizeImage (width, height, true, false, false);
this.vwr.setModelVisibility ();
}}try {
if (type.equals ("JMOL")) type = "ZIPALL";
if (type.equals ("ZIP") || type.equals ("ZIPALL")) {
var scripts = params.get ("scripts");
if (scripts != null && type.equals ("ZIP")) type = "ZIPALL";
sret = this.createZipSet (text, scripts, type.equals ("ZIPALL"), out == null ? this.getOutputChannel (fileName, null) : out, null);
} else if (type.equals ("SCENE")) {
sret = this.createSceneSet (fileName, text, width, height);
} else {
var bytes = params.get ("bytes");
sret = this.vwr.sm.createImage (fileName, type, text, bytes, quality);
if (sret == null) {
var createImage = true;
var captureMsg = null;
if (captureMode != null) {
out = null;
var cparams = this.vwr.captureParams;
var imode = "ad on of en ca mo ".indexOf (captureMode.substring (0, 2));
var rootExt;
if (imode == 15) {
if (cparams != null && cparams.containsKey ("outputChannel")) (cparams.get ("outputChannel")).closeChannel ();
var streaming = params.containsKey ("streaming");
if (streaming && (out = this.getOutputChannel (localName, null)) == null) {
sret = captureMsg = "ERROR: capture canceled";
this.vwr.captureParams = null;
} else {
this.vwr.captureParams = params;
if (params.containsKey ("captureRootExt")) {
imode = 0;
} else {
if (out != null) localName = out.getFileName ();
params.put ("captureFileName", localName);
if (streaming) {
captureMsg = type + "_STREAM_OPEN " + localName;
params.put ("captureMode", "movie");
} else {
rootExt = new Array (2);
params.put ("captureRootExt", JV.OutputManager.getRootExt (localName, rootExt, 0));
localName = JV.OutputManager.getRootExt (null, rootExt, 1);
imode = -1;
cparams = params;
createImage = false;
}}if (!params.containsKey ("captureCount")) params.put ("captureCount", Integer.$valueOf (0));
}}if (imode >= 0 && imode != 15) {
if (cparams == null) {
sret = captureMsg = "ERROR: capture not active";
} else {
params = cparams;
switch (imode) {
default:
sret = captureMsg = "ERROR: CAPTURE MODE=" + captureMode + "?";
break;
case 0:
if (Boolean.FALSE === params.get ("captureEnabled")) {
sret = captureMsg = "capturing OFF; use CAPTURE ON/END/CANCEL to continue";
} else {
var count = JV.OutputManager.getInt (params, "captureCount", 0);
params.put ("captureCount", Integer.$valueOf (++count));
if ((rootExt = params.get ("captureRootExt")) != null) {
localName = JV.OutputManager.getRootExt (null, rootExt, count);
captureMsg = null;
createImage = true;
} else {
captureMsg = type + "_STREAM_ADD " + count;
}}break;
case 3:
case 6:
params = cparams;
params.put ("captureEnabled", (captureMode.equals ("on") ? Boolean.TRUE : Boolean.FALSE));
sret = type + "_STREAM_" + (captureMode.equals ("on") ? "ON" : "OFF");
params.put ("captureMode", "add");
break;
case 9:
case 12:
params = cparams;
params.put ("captureMode", captureMode);
fileName = params.get ("captureFileName");
captureMsg = type + "_STREAM_" + (captureMode.equals ("end") ? "CLOSE " : "CANCEL ") + fileName;
this.vwr.captureParams = null;
params.put ("captureMsg", J.i18n.GT.$ ("Capture") + ": " + (captureMode.equals ("cancel") ? J.i18n.GT.$ ("canceled") : J.i18n.GT.o (J.i18n.GT.$ ("{0} saved"), fileName)));
if (params.containsKey ("captureRootExt")) createImage = false;
break;
}
}}if (createImage && out != null) params.put ("outputChannel", out);
}if (createImage) {
if (localName != null) params.put ("fileName", localName);
if (sret == null) sret = this.writeToOutputChannel (params);
this.vwr.sm.createImage (sret, type, null, null, quality);
if (captureMode != null) {
if (captureMsg == null) captureMsg = sret;
else captureMsg += " (" + params.get (params.containsKey ("captureByteCount") ? "captureByteCount" : "byteCount") + " bytes)";
}}if (captureMsg != null) {
this.vwr.showString (captureMsg, false);
}}}} catch (er) {
er.printStackTrace ();
JU.Logger.error (this.vwr.setErrorMessage (sret = "ERROR creating image??: " + er, null));
} finally {
this.vwr.creatingImage = false;
if (quality != -2147483648 && saveWidth > 0) this.vwr.resizeImage (saveWidth, saveHeight, true, false, true);
}
return sret;
}, "java.util.Map,~B");
Clazz.defineMethod (c$, "setLogFile",
function (value) {
var path = null;
if (this.vwr.logFilePath == null || value.indexOf ("\\") >= 0) {
value = null;
} else if (value.startsWith ("http://") || value.startsWith ("https://")) {
path = value;
} else if (value.indexOf ("/") >= 0) {
value = null;
} else if (value.length > 0) {
if (!value.startsWith ("JmolLog_")) value = "JmolLog_" + value;
path = this.getLogPath (this.vwr.logFilePath + value);
}if (path == null) value = null;
else JU.Logger.info (J.i18n.GT.o (J.i18n.GT.$ ("Setting log file to {0}"), path));
if (value == null || !this.vwr.haveAccess (JV.Viewer.ACCESS.ALL)) {
JU.Logger.info (J.i18n.GT.$ ("Cannot set log file path."));
value = null;
} else {
this.vwr.logFileName = path;
this.vwr.g.setO ("_logFile", this.vwr.isApplet ? value : path);
}return value;
}, "~S");
Clazz.defineMethod (c$, "logToFile",
function (data) {
try {
var doClear = (data.equals ("$CLEAR$"));
if (data.indexOf ("$NOW$") >= 0) data = JU.PT.rep (data, "$NOW$", this.vwr.apiPlatform.getDateFormat (null));
if (this.vwr.logFileName == null) {
JU.Logger.info (data);
return;
}var out = (this.vwr.haveAccess (JV.Viewer.ACCESS.ALL) ? this.openOutputChannel (this.privateKey, this.vwr.logFileName, true, !doClear) : null);
if (!doClear) {
var ptEnd = data.indexOf ('\0');
if (ptEnd >= 0) data = data.substring (0, ptEnd);
out.append (data);
if (ptEnd < 0) out.append ("\n");
}var s = out.closeChannel ();
JU.Logger.info (s);
} catch (e) {
if (Clazz.exceptionOf (e, Exception)) {
if (JU.Logger.debugging) JU.Logger.debug ("cannot log " + data);
} else {
throw e;
}
}
}, "~S");
Clazz.defineMethod (c$, "createZipSet",
function (script, scripts, includeRemoteFiles, out, pngjName) {
var v = new JU.Lst ();
var fm = this.vwr.fm;
var fileNames = new JU.Lst ();
var crcMap = new java.util.Hashtable ();
var haveSceneScript = (scripts != null && scripts.length == 3 && scripts[1].startsWith ("###scene.spt###"));
var sceneScriptOnly = (haveSceneScript && scripts[2].equals ("min"));
if (!sceneScriptOnly) {
JV.FileManager.getFileReferences (script, fileNames);
if (haveSceneScript) JV.FileManager.getFileReferences (scripts[1], fileNames);
}var haveScripts = (!haveSceneScript && scripts != null && scripts.length > 0);
if (haveScripts) {
script = this.wrapPathForAllFiles ("script " + JU.PT.esc (scripts[0]), "");
for (var i = 0; i < scripts.length; i++) fileNames.addLast (scripts[i]);
}var nFiles = fileNames.size ();
var newFileNames = new JU.Lst ();
for (var iFile = 0; iFile < nFiles; iFile++) {
var name = fileNames.get (iFile);
var isLocal = !JV.Viewer.isJS && JU.OC.isLocal (name);
var newName = name;
if (isLocal || includeRemoteFiles) {
var ptSlash = name.lastIndexOf ("/");
newName = (name.indexOf ("?") > 0 && name.indexOf ("|") < 0 ? JU.PT.replaceAllCharacters (name, "/:?\"'=&", "_") : JV.FileManager.stripPath (name));
newName = JU.PT.replaceAllCharacters (newName, "[]", "_");
newName = JU.PT.rep (newName, "#_DOCACHE_", "");
var isSparDir = (fm.spardirCache != null && fm.spardirCache.containsKey (name));
if (isLocal && name.indexOf ("|") < 0 && !isSparDir) {
v.addLast (name);
v.addLast (newName);
v.addLast (null);
} else {
var ret = (isSparDir ? fm.spardirCache.get (name) : fm.getFileAsBytes (name, null));
if (!JU.AU.isAB (ret)) return "ERROR: " + ret;
newName = this.addPngFileBytes (name, ret, iFile, crcMap, isSparDir, newName, ptSlash, v);
}name = "$SCRIPT_PATH$" + newName;
}crcMap.put (newName, newName);
newFileNames.addLast (name);
}
if (!sceneScriptOnly) {
script = JU.PT.replaceQuotedStrings (script, fileNames, newFileNames);
v.addLast ("state.spt");
v.addLast (null);
v.addLast (script.getBytes ());
}if (haveSceneScript) {
if (scripts[0] != null) {
v.addLast ("animate.spt");
v.addLast (null);
v.addLast (scripts[0].getBytes ());
}v.addLast ("scene.spt");
v.addLast (null);
script = JU.PT.replaceQuotedStrings (scripts[1], fileNames, newFileNames);
v.addLast (script.getBytes ());
}var sname = (haveSceneScript ? "scene.spt" : "state.spt");
v.addLast ("JmolManifest.txt");
v.addLast (null);
var sinfo = "# Jmol Manifest Zip Format 1.1\n# Created " + ( new java.util.Date ()) + "\n" + "# JmolVersion " + JV.Viewer.getJmolVersion () + "\n" + sname;
v.addLast (sinfo.getBytes ());
v.addLast ("Jmol_version_" + JV.Viewer.getJmolVersion ().$replace (' ', '_').$replace (':', '.'));
v.addLast (null);
v.addLast ( Clazz.newByteArray (0, 0));
if (out.getFileName () != null) {
var bytes = this.vwr.getImageAsBytes ("PNG", 0, 0, -1, null);
if (bytes != null) {
v.addLast ("preview.png");
v.addLast (null);
v.addLast (bytes);
}}return this.writeZipFile (out, v, "OK JMOL", pngjName);
}, "~S,~A,~B,JU.OC,~S");
Clazz.defineMethod (c$, "addPngFileBytes",
function (name, ret, iFile, crcMap, isSparDir, newName, ptSlash, v) {
var crcValue = Integer.$valueOf (this.vwr.getJzt ().getCrcValue (ret));
if (crcMap.containsKey (crcValue)) {
newName = crcMap.get (crcValue);
} else {
if (isSparDir) newName = newName.$replace ('.', '_');
if (crcMap.containsKey (newName)) {
var pt = newName.lastIndexOf (".");
if (pt > ptSlash) newName = newName.substring (0, pt) + "[" + iFile + "]" + newName.substring (pt);
else newName = newName + "[" + iFile + "]";
}v.addLast (name);
v.addLast (newName);
v.addLast (ret);
crcMap.put (crcValue, newName);
}return newName;
}, "~S,~A,~N,java.util.Hashtable,~B,~S,~N,JU.Lst");
Clazz.defineMethod (c$, "writeZipFile",
function (out, fileNamesAndByteArrays, msg, pngjName) {
var buf = Clazz.newByteArray (1024, 0);
var nBytesOut = 0;
var nBytes = 0;
var outFileName = out.getFileName ();
if (pngjName != null && pngjName.startsWith ("//")) pngjName = "file:" + pngjName.substring (1);
JU.Logger.info ("creating zip file " + (outFileName == null ? "" : outFileName) + "...");
var fileList = "";
try {
var bos;
{
bos = out;
}var fm = this.vwr.fm;
var zos = this.vwr.getJzt ().getZipOutputStream (bos);
for (var i = 0; i < fileNamesAndByteArrays.size (); i += 3) {
var fname = fileNamesAndByteArrays.get (i);
var bytes = null;
var data = fm.cacheGet (fname, false);
if (Clazz.instanceOf (data, java.util.Map)) continue;
if (fname.indexOf ("file:/") == 0) {
fname = fname.substring (5);
if (fname.length > 2 && fname.charAt (2) == ':') fname = fname.substring (1);
} else if (fname.indexOf ("cache://") == 0) {
fname = fname.substring (8);
}var fnameShort = fileNamesAndByteArrays.get (i + 1);
if (fnameShort == null) fnameShort = fname;
if (data != null) bytes = (JU.AU.isAB (data) ? data : (data).getBytes ());
if (bytes == null) bytes = fileNamesAndByteArrays.get (i + 2);
var key = ";" + fnameShort + ";";
if (fileList.indexOf (key) >= 0) {
JU.Logger.info ("duplicate entry");
continue;
}fileList += key;
this.vwr.getJzt ().addZipEntry (zos, fnameShort);
var nOut = 0;
if (bytes == null) {
var $in = this.vwr.getBufferedInputStream (fname);
var len;
while ((len = $in.read (buf, 0, 1024)) > 0) {
zos.write (buf, 0, len);
nOut += len;
}
$in.close ();
} else {
zos.write (bytes, 0, bytes.length);
if (pngjName != null) this.vwr.fm.recachePngjBytes (pngjName + "|" + fnameShort, bytes);
nOut += bytes.length;
}nBytesOut += nOut;
this.vwr.getJzt ().closeZipEntry (zos);
JU.Logger.info ("...added " + fname + " (" + nOut + " bytes)");
}
zos.flush ();
zos.close ();
JU.Logger.info (nBytesOut + " bytes prior to compression");
var ret = out.closeChannel ();
if (ret != null) {
if (ret.indexOf ("Exception") >= 0) return ret;
msg += " " + ret;
}nBytes = out.getByteCount ();
} catch (e) {
if (Clazz.exceptionOf (e, java.io.IOException)) {
JU.Logger.info (e.toString ());
return e.toString ();
} else {
throw e;
}
}
var fileName = out.getFileName ();
return (fileName == null ? null : msg + " " + nBytes + " " + fileName);
}, "JU.OC,JU.Lst,~S,~S");
Clazz.defineMethod (c$, "wrapPathForAllFiles",
function (cmd, strCatch) {
var vname = "v__" + ("" + Math.random ()).substring (3);
return "# Jmol script\n{\n\tVar " + vname + " = pathForAllFiles\n\tpathForAllFiles=\"$SCRIPT_PATH$\"\n\ttry{\n\t\t" + cmd + "\n\t}catch(e){" + strCatch + "}\n\tpathForAllFiles = " + vname + "\n}\n";
}, "~S,~S");
Clazz.defineStatics (c$,
"SCENE_TAG", "###scene.spt###");
});