Package com.subgraph.vega.application

Source Code of com.subgraph.vega.application.Application

/*******************************************************************************
* Copyright (c) 2011 Subgraph.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
*     Subgraph - initial API and implementation
******************************************************************************/
package com.subgraph.vega.application;

import java.io.File;
import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.logging.Handler;
import java.util.logging.Level;
import java.util.logging.Logger;

import org.eclipse.core.runtime.Platform;
import org.eclipse.equinox.app.IApplication;
import org.eclipse.equinox.app.IApplicationContext;
import org.eclipse.jface.dialogs.MessageDialog;
import org.eclipse.osgi.service.datalocation.Location;
import org.eclipse.swt.widgets.Display;
import org.eclipse.ui.IWorkbench;
import org.eclipse.ui.PlatformUI;

import com.subgraph.vega.api.console.IConsole;
import com.subgraph.vega.api.model.IModel;
import com.subgraph.vega.api.paths.IPathFinder;
import com.subgraph.vega.application.console.ConsoleHandler;
import com.subgraph.vega.application.logging.LogFormatter;
import com.subgraph.vega.application.logging.LogHandler;

/**
* This class controls all aspects of the application's execution
*/
public class Application implements IApplication {

  /* (non-Javadoc)
   * @see org.eclipse.equinox.app.IApplication#start(org.eclipse.equinox.app.IApplicationContext)
   */
 
  public Object start(IApplicationContext context) throws Exception {
    Display display = PlatformUI.createDisplay();
    setupLogging();
   
    if(!lockInstance()) {
      MessageDialog.openError(null, "Vega already running", "An instance of the Vega application is already running.");
      return IApplication.EXIT_OK;
    }
    if(!setupWorkspace()) {
      return IApplication.EXIT_OK;
    }
    ConsoleHandler consoleHandler = new ConsoleHandler(display, Activator.getDefault().getConsole());
    consoleHandler.activate();
   
    try {
      int returnCode = PlatformUI.createAndRunWorkbench(display, new ApplicationWorkbenchAdvisor());
      if (returnCode == PlatformUI.RETURN_RESTART)
        return IApplication.EXIT_RESTART;
      else
        return IApplication.EXIT_OK;
    } finally {
      display.dispose();
    }
   
  }

  private boolean lockInstance() {
    final URL url = getLockLocationURL();
    if(url != null) {
      final Location loc = Platform.getInstanceLocation();
      try {
        if(!loc.isSet()) {
          loc.set(url, false);
        }
        if(loc.isLocked()) {
          return false;
        }
        loc.lock();
        return true;
      } catch (IllegalStateException e) {
        MessageDialog.openWarning(null, "Warning", "Exception trying to lock Vega instance: "+ e.getMessage());
      } catch (IOException e) {
        MessageDialog.openWarning(null, "Warning", "I/O Exception trying to lock Vega instance: "+ e.getMessage());
      }
    }
    return true;
  }
 
  private URL getLockLocationURL() {
    final IPathFinder pathFinder = Activator.getDefault().getPathFinder();
    final File path = pathFinder.getWorkspaceDirectory();
    try {
      return new URL("file:"+ path.getPath());
    } catch (MalformedURLException e) {
      return null;
    }
  }
  private void setupLogging() {
    Logger rootLogger = Logger.getLogger("");

    IConsole console = Activator.getDefault().getConsole();
    if(console != null) {
      Handler handler = new LogHandler(console);
      handler.setFormatter(new LogFormatter());
      handler.setLevel(Level.FINEST);
      for(Handler h: rootLogger.getHandlers())
        rootLogger.removeHandler(h);
      rootLogger.addHandler(handler);
    }
   
    rootLogger.setLevel(Level.WARNING);
  }

  private boolean setupWorkspace() {
    final IModel model = Activator.getDefault().getModel();
    if(model == null) {
      MessageDialog.openError(null, "Initialization Error", "Failed to obtain model service");
      return false;
    }
    if(!model.openDefaultWorkspace()) {
      MessageDialog.openError(null, "Initialization Error", "Could not open workspace");
      return false;
    }
    return true;
  }
 
  /* (non-Javadoc)
   * @see org.eclipse.equinox.app.IApplication#stop()
   */
  public void stop() {
    if (!PlatformUI.isWorkbenchRunning())
      return;
    final IWorkbench workbench = PlatformUI.getWorkbench();
    final Display display = workbench.getDisplay();
    display.syncExec(new Runnable() {
      public void run() {
        if (!display.isDisposed())
          workbench.close();
      }
    });
  }
}
TOP

Related Classes of com.subgraph.vega.application.Application

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.