diff options
Diffstat (limited to 'org.openembedded.bc.ui/src/org/openembedded/bc/ui/views')
-rw-r--r-- | org.openembedded.bc.ui/src/org/openembedded/bc/ui/views/RecipeContentProvider.java | 65 | ||||
-rw-r--r-- | org.openembedded.bc.ui/src/org/openembedded/bc/ui/views/RecipeView.java | 165 |
2 files changed, 230 insertions, 0 deletions
diff --git a/org.openembedded.bc.ui/src/org/openembedded/bc/ui/views/RecipeContentProvider.java b/org.openembedded.bc.ui/src/org/openembedded/bc/ui/views/RecipeContentProvider.java new file mode 100644 index 0000000..3482b9b --- /dev/null +++ b/org.openembedded.bc.ui/src/org/openembedded/bc/ui/views/RecipeContentProvider.java @@ -0,0 +1,65 @@ +/***************************************************************************** + * Copyright (c) 2009 Ken Gilmer + * 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: + * Ken Gilmer - initial API and implementation + *******************************************************************************/ +package org.openembedded.bc.ui.views; + +import java.util.ArrayList; +import java.util.Collection; +import java.util.List; + +import org.eclipse.core.resources.IProject; +import org.eclipse.core.resources.IProjectNature; +import org.eclipse.core.resources.ResourcesPlugin; +import org.eclipse.core.runtime.CoreException; +import org.eclipse.jface.viewers.IStructuredContentProvider; +import org.eclipse.jface.viewers.Viewer; +import org.openembedded.bc.bitbake.BBSession; +import org.openembedded.bc.ui.Activator; +import org.openembedded.bc.ui.builder.BitbakeCommanderNature; + + +class RecipeContentProvider implements IStructuredContentProvider { + public void dispose() { + } + + public Object[] getElements(Object parent) { + List recipes = new ArrayList(); + IProject[] projects = ResourcesPlugin.getWorkspace().getRoot().getProjects(); + IProjectNature nature = null; + for (int i = 0; i < projects.length; ++i) { + try { + if (projects[i].isOpen() && projects[i].hasNature(BitbakeCommanderNature.NATURE_ID)) { + recipes.addAll(getRecipesFromProject(projects[i])); + } + } catch (CoreException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + } + + return recipes.toArray(); + } + + private Collection getRecipesFromProject(IProject project) throws Exception { + BBSession session = Activator.getBBSession(project.getLocationURI().getPath(), null); + + if (!session.isInitialized()) { + session.initialize(); + } + + return session.getRecipeFiles(project); + } + + public void inputChanged(Viewer v, Object oldInput, Object newInput) { + } +}
\ No newline at end of file diff --git a/org.openembedded.bc.ui/src/org/openembedded/bc/ui/views/RecipeView.java b/org.openembedded.bc.ui/src/org/openembedded/bc/ui/views/RecipeView.java new file mode 100644 index 0000000..844a75e --- /dev/null +++ b/org.openembedded.bc.ui/src/org/openembedded/bc/ui/views/RecipeView.java @@ -0,0 +1,165 @@ +/***************************************************************************** + * Copyright (c) 2009 Ken Gilmer + * 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: + * Ken Gilmer - initial API and implementation + *******************************************************************************/ +package org.openembedded.bc.ui.views; + +import org.eclipse.core.resources.IFile; +import org.eclipse.jface.action.Action; +import org.eclipse.jface.action.IMenuListener; +import org.eclipse.jface.action.IMenuManager; +import org.eclipse.jface.action.IToolBarManager; +import org.eclipse.jface.action.MenuManager; +import org.eclipse.jface.action.Separator; +import org.eclipse.jface.viewers.DoubleClickEvent; +import org.eclipse.jface.viewers.IDoubleClickListener; +import org.eclipse.jface.viewers.ISelection; +import org.eclipse.jface.viewers.IStructuredSelection; +import org.eclipse.jface.viewers.ITableLabelProvider; +import org.eclipse.jface.viewers.LabelProvider; +import org.eclipse.jface.viewers.TableViewer; +import org.eclipse.jface.viewers.ViewerSorter; +import org.eclipse.swt.SWT; +import org.eclipse.swt.graphics.Image; +import org.eclipse.swt.widgets.Composite; +import org.eclipse.swt.widgets.Menu; +import org.eclipse.ui.IActionBars; +import org.eclipse.ui.ISharedImages; +import org.eclipse.ui.IWorkbenchActionConstants; +import org.eclipse.ui.PartInitException; +import org.eclipse.ui.PlatformUI; +import org.eclipse.ui.part.FileEditorInput; +import org.eclipse.ui.part.ViewPart; +import org.openembedded.bc.ui.editors.bitbake.BitBakeFileEditor; + + +public class RecipeView extends ViewPart { + class ViewLabelProvider extends LabelProvider implements ITableLabelProvider { + public Image getColumnImage(Object obj, int index) { + return getImage(obj); + } + + public String getColumnText(Object obj, int index) { + + if (obj instanceof IFile) { + return ((IFile) obj).getName(); + } + + return getText(obj); + } + + @Override + public Image getImage(Object obj) { + return PlatformUI.getWorkbench().getSharedImages().getImage(ISharedImages.IMG_OBJ_FILE); + } + } + public static final String ID_VIEW = "org.openembedded.bc.ui.views.RecipeView"; +private TableViewer viewer; + + /* private Action action1; + private Action action2; + */ private Action doubleClickAction; + + private void contributeToActionBars() { + IActionBars bars = getViewSite().getActionBars(); + fillLocalPullDown(bars.getMenuManager()); + fillLocalToolBar(bars.getToolBarManager()); + } + + @Override + public void createPartControl(Composite parent) { + viewer = new TableViewer(parent, SWT.MULTI | SWT.H_SCROLL | SWT.V_SCROLL); + viewer.setContentProvider(new RecipeContentProvider()); + viewer.setLabelProvider(new ViewLabelProvider()); + viewer.setSorter(new ViewerSorter()); + viewer.setInput(getViewSite()); + makeActions(); + hookContextMenu(); + hookDoubleClickAction(); + contributeToActionBars(); + } + + private void fillContextMenu(IMenuManager manager) { +/* manager.add(action1); + manager.add(action2); +*/ // Other plug-ins can contribute there actions here + manager.add(new Separator(IWorkbenchActionConstants.MB_ADDITIONS)); + } + + private void fillLocalPullDown(IMenuManager manager) { +/* manager.add(action1); + manager.add(new Separator()); + manager.add(action2); +*/ } + + private void fillLocalToolBar(IToolBarManager manager) { +/* manager.add(action1); + manager.add(action2); +*/ } + + private void hookContextMenu() { + MenuManager menuMgr = new MenuManager("#PopupMenu"); + menuMgr.setRemoveAllWhenShown(true); + menuMgr.addMenuListener(new IMenuListener() { + public void menuAboutToShow(IMenuManager manager) { + RecipeView.this.fillContextMenu(manager); + } + }); + Menu menu = menuMgr.createContextMenu(viewer.getControl()); + viewer.getControl().setMenu(menu); + getSite().registerContextMenu(menuMgr, viewer); + } + + private void hookDoubleClickAction() { + viewer.addDoubleClickListener(new IDoubleClickListener() { + public void doubleClick(DoubleClickEvent event) { + doubleClickAction.run(); + } + }); + } + + private void makeActions() { +/* action1 = new Action() { + public void run() { + } + }; + action1.setText("Action 1"); + action1.setToolTipText("Action 1 tooltip"); + action1.setImageDescriptor(PlatformUI.getWorkbench().getSharedImages().getImageDescriptor(ISharedImages.IMG_OBJS_INFO_TSK)); + + action2 = new Action() { + public void run() { + } + }; + action2.setText("Action 2"); + action2.setToolTipText("Action 2 tooltip"); + action2.setImageDescriptor(PlatformUI.getWorkbench().getSharedImages().getImageDescriptor(ISharedImages.IMG_OBJS_INFO_TSK)); +*/ doubleClickAction = new Action() { + @Override + public void run() { + ISelection selection = viewer.getSelection(); + Object obj = ((IStructuredSelection) selection).getFirstElement(); + + if (obj instanceof IFile) { + try { + RecipeView.this.getViewSite().getPage().openEditor(new FileEditorInput((IFile) obj), BitBakeFileEditor.EDITOR_ID); + } catch (PartInitException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + } + } + }; + } + + @Override + public void setFocus() { + viewer.getControl().setFocus(); + } +}
\ No newline at end of file |