/* * #%L * gitools-ui-app * %% * Copyright (C) 2013 Universitat Pompeu Fabra - Biomedical Genomics group * %% * 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 * <http://www.gnu.org/licenses/gpl-3.0.html>. * #L% */ package org.gitools.ui.app.actions.file; import com.google.common.collect.Sets; import org.apache.commons.lang.StringUtils; import org.gitools.api.analysis.IProgressMonitor; import org.gitools.heatmap.Heatmap; import org.gitools.ui.core.Application; import org.gitools.ui.core.actions.HeatmapAction; import org.gitools.ui.core.commands.AbstractCommand; import org.gitools.ui.platform.icons.IconNames; import org.gitools.ui.platform.progress.JobRunnable; import org.gitools.ui.platform.progress.JobThread; import org.gitools.ui.platform.settings.Settings; import javax.swing.*; import java.awt.event.ActionEvent; import java.io.*; import java.net.ConnectException; import java.net.Socket; import java.net.SocketTimeoutException; import java.util.Set; /** * This actions sends a command to IGV (Integrative Genomic Viewer) to do a search * of the current selected row identifiers. The user must have IGV running and a * track with the row identifiers loaded. */ public class OpenIntegrativeGenomicViewerAction extends HeatmapAction { /** * Instantiates a new Open integrative genomic viewer action. */ public OpenIntegrativeGenomicViewerAction() { super("open current selection in IGV"); setLargeIconFromResource(IconNames.igv24); setSmallIconFromResource(IconNames.igv16); } /** * Show a popup dialog with an informative message * * @param message the message */ private static void showMessage(String message) { Application frame = Application.get(); JOptionPane.showMessageDialog(frame, message); } @Override public void actionPerformed(ActionEvent e) { Heatmap heatmap = getHeatmap(); // No row selected Set<String> rows = heatmap.getRows().getSelected(); if (heatmap.getRows().getFocus() == null && rows.size() == 0) { showMessage("Please select one or more rows"); return; } // If there are no rows selected use the row of the current cell selection if (rows.size() == 0) { rows = Sets.newHashSet(heatmap.getRows().getFocus()); } // Execute the command JobRunnable loadFile = new IgvCommand(StringUtils.join(rows, " ")); JobThread.execute(Application.get(), loadFile); Application.get().showNotification("Opened in IGV."); } private class IgvCommand extends AbstractCommand { private final String rowQuery; private IgvCommand(String rowQuery) { this.rowQuery = rowQuery; } @Override public void execute(IProgressMonitor monitor) { Socket socket = null; try { monitor.title("Connecting with Integrative Genomics Viewer"); String igvUrl[] = Settings.get().getIgvUrl().replace("http://", "").split(":"); socket = new Socket(igvUrl[0], Integer.valueOf(igvUrl[1])); System.out.println(); socket.setSoTimeout(30000); PrintWriter out = new PrintWriter(socket.getOutputStream(), true); InputStream in = socket.getInputStream(); String cmd; monitor.info("Locating '" + rowQuery + "'"); cmd = "goto " + rowQuery; out.println(cmd); waitServerResponse(in, monitor); } catch (ConnectException e) { showMessage("Unable to connect with Integrative Genomics Viewer (IGV). " + "\n It must be running on '" + Settings.get().getIgvUrl() + "'. " + "\n Install or launch it from 'http://www.broadinstitute.org/igv'."); setExitStatus(1); } catch (SocketTimeoutException e) { showMessage("Timeout connecting with Integrative Genomics Viewer (IGV) on '" + Settings.get().getIgvUrl() + "'. "); setExitStatus(1); } catch (IOException e) { showMessage("Unknwn problem 'e.getMessage()' connecting with Integrative Genomics Viewer (IGV). Check Gitools help."); setExitStatus(1); } catch (UnsupportedOperationException e) { setExitStatus(1); } finally { if (socket != null) { try { socket.close(); } catch (IOException e) { e.printStackTrace(); } } } setExitStatus(0); } private void waitServerResponse(InputStream in, IProgressMonitor monitor) throws UnsupportedOperationException, IOException { while (in.available() == 0) { try { Thread.sleep(1000); } catch (Exception ee) { } if (monitor.isCancelled()) { throw new UnsupportedOperationException("User cancel"); } } BufferedReader reader = new BufferedReader(new InputStreamReader(in)); reader.readLine(); } } }