Path: blob/aarch64-shenandoah-jdk8u272-b10/nashorn/samples/console.js
32278 views
/*1* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.2*3* Redistribution and use in source and binary forms, with or without4* modification, are permitted provided that the following conditions5* are met:6*7* - Redistributions of source code must retain the above copyright8* notice, this list of conditions and the following disclaimer.9*10* - Redistributions in binary form must reproduce the above copyright11* notice, this list of conditions and the following disclaimer in the12* documentation and/or other materials provided with the distribution.13*14* - Neither the name of Oracle nor the names of its15* contributors may be used to endorse or promote products derived16* from this software without specific prior written permission.17*18* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS19* IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,20* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR21* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR22* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,23* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,24* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR25* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF26* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING27* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS28* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.29*/3031/**32* Simple Web Console-like support for Nashorn. In addition to33* Web console object methods, this console add methods of34* java.io.Console as well. Note:not all web console methods are35* implemented but useful subset is implemented.36*37* See also: https://developer.mozilla.org/en/docs/Web/API/console38*/394041if (typeof console == 'undefined') {4243(function() {44var LocalDateTime = Java.type("java.time.LocalDateTime");45var System = Java.type("java.lang.System");46var jconsole = System.console();4748// add a new global variable called "console"49this.console = {50};5152function addConsoleMethods() {53// expose methods of java.io.Console as an extension54var placeholder = "-*-";55// put a placeholder for each name from java.lang.Object56var objMethods = Object.bindProperties({}, new java.lang.Object());57for (var m in objMethods) {58console[m] = placeholder;59}6061// bind only the methods of java.io.Console62// This bind will skip java.lang.Object methods as console63// has properties of same name.64Object.bindProperties(console, jconsole);6566// Now, delete java.lang.Object methods67for (var m in console) {68if (console[m] == placeholder) {69delete console[m];70}71}72}7374addConsoleMethods();7576function consoleLog(type, msg) {77// print type of message, then time.78jconsole.format("%s [%s] ", type, LocalDateTime.now().toString());79if (typeof msg == 'string') {80jconsole.format(msg + "\n", Array.prototype.slice.call(arguments, 2));81} else {82// simple space separated values and newline at the end83var arr = Array.prototype.slice.call(arguments, 1);84jconsole.format("%s\n", arr.join(" "));85}86}8788console.toString = function() "[object Console]";8990// web console functions9192console.assert = function(expr) {93if (! expr) {94arguments[0] = "Assertion Failed:";95consoleLog.apply(console, arguments);96// now, stack trace at the end97jconsole.format("%s\n", new Error().stack);98}99};100101// dummy clear to avoid error!102console.clear = function() {};103104var counter = {105get: function(label) {106if (! this[label]) {107return this[label] = 1;108} else {109return ++this[label];110}111}112};113114// counter115console.count = function(label) {116label = label? String(label) : "<no label>";117jconsole.format("%s: %d\n",label, counter.get(label).intValue());118}119120// logging121console.error = consoleLog.bind(jconsole, "ERROR");122console.info = consoleLog.bind(jconsole, "INFO");123console.log = console.info;124console.debug = console.log;125console.warn = consoleLog.bind(jconsole, "WARNING");126127// print stack trace128console.trace = function() {129jconsole.format("%s\n", new Error().stack);130};131})();132133}134135136