print(e.javaException); // это обертка для java.lang.NullPointerException
}
Здесь необходимо сделать последнее замечание по поводу преобразования типов в Rhino. Интерпретатор Rhino автоматически
преобразует простые числа, логические значения и null. Java-тип char интерпретируется в языке JavaScript как число, так как в языке JavaScript отсутствует символьный тип. JavaScript-строки автоматически преобразуются в Java-строки, но (и это может быть камнем преткновения) Java-строки остаются объектами
java.lang.String
и не преобразуются обратно в JavaScript-строки. Взгляните на следующую строку из примера, приводившегося ранее:
var version = java.lang.System.getProperty("java.version");
После выполнения этой инструкции переменная version будет хранить объект java.lang.String. Он обычно ведет себя как JavaScript-строка, но существуют важные отличия. Во-первых, Java-строка вместо свойства length имеет метод length. Во-вторых, оператор typeof возвращает тип «object» для Java-строк. Java-строку нельзя преобразовать в JavaScript-строку вызовом метода toString, потому что все Java-объекты имеют собственные методы toString, возвращающие экземпляры javadang.String. Чтобы преобразовать Java-значение в строку, его нужно передать JavaScript-функции String:
var version = String(java.lang.System.getPropertyC'java.version"));
12.1.1. Пример использования Rhino
В примере 12.1 приводится простое приложение для интерпретатора Rhino, демонстрирующее большую часть возможностей и приемов, описанных выше. Пример использует пакет javax.swing со средствами построения графических интерфейсов, пакет java.net с инструментами организации сетевых взаимодействий, пакет java.io потокового ввода/вывода и инструменты языка Java многопоточного выполнения для реализации простого приложения менеджера загрузки, которое загружает файлы по адресам URL и отображает ход выполнения загрузки. На рис. 12.1 показано, как выглядит окно приложения в процессе загрузки двух файлов.
Пример 12.1. Приложение менеджера загрузки для Rhino
/*
* Приложение менеджера загрузки с простым графическим интерфейсом,
* построенным средствами языка Java
*/
// Импортировать графические компоненты из библиотеки Swing
// и несколько других классов
importPackage(javax.swing);
importClass(javax.swing.border.EmptyBorder);
importClass(java.awt.event.ActionListener);
importClass(java.net.URL);
importClass(java.io.FileOutputStream);
importClass(java.lang.Thread);
//
Создать графические элементы управления
var frame = new JFrame("Rhino URL Fetcher"); // Окно приложения
var urlfield = new JTextField(30); // Поле ввода URL
var button = new JButton("Download"); // Кнопка запуска загрузки
var fil-echooser = new JFileChooser; // Диалог выбора файла
var row = Box.createHorizontalBox; // Контейнер для поля и кнопки
var col = Box.createVerticalBox; // Для строки и индикатора хода
// выполнения операции
var padding = new EmptyBorder(3.3,3,3); // Отступы для строк
// Объединить все компоненты и отобразить графический интерфейс
row.add(urlfield); // Поместить поле ввода в строку
row.add(button); // Поместить кнопку в строку
col.add(row);// Поместить строку в колонку
frame.add(col); // Поместить колонку во фрейм
row.setBorder(padding); // Добавить отступы вокруг строки
frame.pack; // Определить минимальный размер
frame.visible = true; // Вывести окно
// Эта функция вызывается, когда в окне что-то происходит,
frame.addWindowListener(function(e, name) {
// Если пользователь закрыл окно, завершить приложение,
if (name === "windowclosing") // Rhino добавляет аргумент name
java.lang.System.exit(0);
});
// Эта функция вызывается, когда пользователь щелкает на кнопке
button.addActionListener(function {
try {
// Создать объект java.net.URL для представления URL источника.
// (Автоматически будет проверена корректность ввода пользователя)
var url = new URL(urlfield.text);
// Предложить пользователю выбрать файл для сохранения содержимого URL
var response = filechooser.showSaveDialog(fгате);
// Завершить, если пользователь щелкнул на кнопке Cancel
if (response != JFileChooser.APPROVE.OPTION) return;
// Иначе получить объект java.io.File, представляющий файл назначения