[yocto] [Refactor RFC 4/9] Remove unused Bitbake Actions
Zhang, Jessica
jessica.zhang at intel.com
Thu Jun 6 16:57:52 PDT 2013
We can't remove them, since we should support build a specific recipe as from the command line.
-----Original Message-----
From: yocto-bounces at yoctoproject.org [mailto:yocto-bounces at yoctoproject.org] On Behalf Of Ioana Grigoropol
Sent: Tuesday, June 04, 2013 6:26 AM
To: yocto at yoctoproject.org
Subject: [yocto] [Refactor RFC 4/9] Remove unused Bitbake Actions
- none of the Bitbake action classes that inherit from AbstractBitbakeCommandAction is used -> clean-up classes & plugin.xml
Signed-off-by: Ioana Grigoropol <ioanax.grigoropol at intel.com>
---
plugins/org.yocto.bc.ui/plugin.xml | 55 ------
.../ui/actions/AbstractBitbakeCommandAction.java | 198 --------------------
.../bc/ui/actions/BitbakeBuildRecipeAction.java | 24 ---
.../bc/ui/actions/BitbakeCleanRecipeAction.java | 26 ---
.../yocto/bc/ui/actions/BitbakeImportAction.java | 106 -----------
.../bc/ui/actions/BitbakeRebuildRecipeAction.java | 29 ---
6 files changed, 438 deletions(-)
delete mode 100644 plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/AbstractBitbakeCommandAction.java
delete mode 100644 plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeBuildRecipeAction.java
delete mode 100644 plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeCleanRecipeAction.java
delete mode 100644 plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeImportAction.java
delete mode 100644 plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeRebuildRecipeAction.java
diff --git a/plugins/org.yocto.bc.ui/plugin.xml b/plugins/org.yocto.bc.ui/plugin.xml
index cb0561c..2e1421f 100644
--- a/plugins/org.yocto.bc.ui/plugin.xml
+++ b/plugins/org.yocto.bc.ui/plugin.xml
@@ -39,61 +39,6 @@
commandId="org.yocto.bc.ui.command.launchHob">
</handler>
</extension>
- <!--
- <extension
- point="org.eclipse.ui.popupMenus">
- <objectContribution
- adaptable="true"
- id="org.yocto.bc.ui.contribution2"
- nameFilter="*.bb"
- objectClass="org.eclipse.core.resources.IFile">
- <action
- class="org.yocto.bc.ui.actions.BitbakeBuildRecipeAction"
- enablesFor="+"
- icon="icons/binary.gif"
- id="org.yocto.bc.ui.BuildPackagePopupAction"
- label="Build"
- menubarPath="org.yocto.bc.ui.menu1/group1"
- tooltip="Build a package">
- </action>
- <action
- class="org.yocto.bc.ui.actions.BitbakeCleanRecipeAction"
- enablesFor="+"
- icon="icons/trash.gif"
- id="org.yocto.bc.ui.CleanPackagePopupAction"
- label="Clean"
- menubarPath="org.yocto.bc.ui.menu1/group1"
- tooltip="Clean a package">
- </action>
- <action
- class="org.yocto.bc.ui.actions.BitbakeImportAction"
- enablesFor="+"
- icon="icons/import_wiz.gif"
- id="org.yocto.bc.ui.BitbakeImportPopupAction"
- label="Import"
- menubarPath="org.yocto.bc.ui.menu1/group1"
- tooltip="Import package sources as Eclipse project.">
- </action>
- <menu
- id="org.yocto.bc.ui.menu1"
- label="BitBake"
- path="additions">
- <separator
- name="bc.separator1">
- </separator>
- </menu>
- <action
- class="org.yocto.bc.ui.actions.BitbakeRebuildRecipeAction"
- enablesFor="+"
- icon="icons/refresh.gif"
- id="org.yocto.bc.ui.BuildPackagePopupAction"
- label="Rebuild"
- menubarPath="org.yocto.bc.ui.menu1/group1"
- tooltip="Rebuild a package">
- </action>
- </objectContribution>
- </extension>
- -->
<extension
point="org.eclipse.ui.menus">
<menuContribution
diff --git a/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/AbstractBitbakeCommandAction.java b/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/AbstractBitbakeCommandAction.java
deleted file mode 100644
index cd4f4c9..0000000
--- a/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/AbstractBitbakeCommandAction.java
+++ /dev/null
@@ -1,198 +0,0 @@
-/*****************************************************************************
- * 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.yocto.bc.ui.actions;
-
-import java.io.IOException;
-
-import org.eclipse.core.resources.IFile; -import org.eclipse.core.resources.IProject;
-import org.eclipse.core.runtime.CoreException;
-import org.eclipse.core.runtime.IProgressMonitor;
-import org.eclipse.core.runtime.IStatus; -import org.eclipse.core.runtime.Status; -import org.eclipse.core.runtime.jobs.Job;
-import org.eclipse.jface.action.IAction; -import org.eclipse.jface.preference.JFacePreferences;
-import org.eclipse.jface.resource.JFaceResources;
-import org.eclipse.jface.viewers.ISelection;
-import org.eclipse.jface.viewers.IStructuredSelection;
-import org.eclipse.swt.graphics.Color;
-import org.eclipse.ui.IWorkbenchWindow; -import org.eclipse.ui.IWorkbenchWindowActionDelegate;
-import org.eclipse.ui.console.MessageConsole;
-import org.eclipse.ui.console.MessageConsoleStream;
-import org.yocto.bc.bitbake.BBLanguageHelper;
-import org.yocto.bc.bitbake.BBSession;
-import org.yocto.bc.ui.Activator;
-import org.yocto.bc.ui.builder.BitbakeCommanderNature;
-import org.yocto.remote.utils.ICommandResponseHandler;
-
-public abstract class AbstractBitbakeCommandAction implements IWorkbenchWindowActionDelegate {
-
- private class CommandJob extends Job {
-
- public CommandJob() {
- super(getJobTitle());
- }
-
- @Override
- protected IStatus run(IProgressMonitor monitor) {
- String cmds[] = getCommands();
- return execCommands(cmds, monitor);
- }
-
- }
- protected IAction action;
- protected IFile recipe;
- protected BBSession bbs;
-
- private Color commandColor, responseColor, errorColor;
- private boolean errorOccurred = false;
-
- public AbstractBitbakeCommandAction() {
- commandColor = JFaceResources.getColorRegistry().get(JFacePreferences.ACTIVE_HYPERLINK_COLOR);
- responseColor = JFaceResources.getColorRegistry().get(JFacePreferences.HYPERLINK_COLOR);
- errorColor = JFaceResources.getColorRegistry().get(JFacePreferences.ERROR_COLOR);
- }
-
- private void checkEnabled(IFile file) {
- try {
- if (file.getFileExtension() == null || !file.getFileExtension().equals(BBLanguageHelper.BITBAKE_RECIPE_FILE_EXTENSION)) {
- action.setEnabled(false);
- return;
- }
-
- IProject project = file.getProject();
- if (!(project.hasNature(BitbakeCommanderNature.NATURE_ID))) {
- action.setEnabled(false);
- return;
- }
-
- bbs = Activator.getBBSession(project.getLocationURI().getPath());
-
- if (bbs != null) {
- recipe = file;
- action.setEnabled(true);
- }
-
- } catch (CoreException e) {
- action.setEnabled(false);
- e.printStackTrace();
- } catch (Exception e) {
- action.setEnabled(false);
- e.printStackTrace();
- }
- }
-
- public void dispose() {
- }
-
- /**
- * Execute array of commands with bitbake and put output in console.
- *
- * @param cmds
- * @param monitor
- * @return
- */
- protected IStatus execCommands(String[] cmds, final IProgressMonitor monitor) {
- MessageConsole mc = bbs.getConsole();
- final MessageConsoleStream cmd = mc.newMessageStream();
- cmd.setColor(commandColor);
- final MessageConsoleStream out = mc.newMessageStream();
- final MessageConsoleStream err = mc.newMessageStream();
- err.setColor(errorColor);
-
- try {
- for (int i = 0; i < cmds.length; ++i) {
- cmd.println(cmds[i]);
- monitor.subTask(cmds[i]);
- bbs.getShell().execute(cmds[i], new ICommandResponseHandler() {
-
- public void response(String line, boolean isError) {
- if (monitor.isCanceled()) {
- cmd.println("Interrupting process by user request.");
- bbs.getShell().interrupt();
- }
-
- if (isError) {
- err.println(line);
- errorOccurred();
- } else if (line.startsWith("ERROR:")) {
- err.println(line);
- } else {
- out.println(line);
- }
- }
- });
- }
- } catch (IOException e) {
- return new Status(IStatus.ERROR, Activator.PLUGIN_ID, e.getMessage(), e);
- } finally {
- try {
- if (errorOccurred) {
- cmd.println("At least one error occured while executing this command. Check output for more details.");
- }
- cmd.close();
- out.close();
- err.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
-
- return Status.OK_STATUS;
- }
-
- protected void errorOccurred() {
- errorOccurred = true;
- }
-
- /**
- * Return the command to be executed.
- *
- * @return
- */
- public abstract String[] getCommands();
-
- public Job getJob() {
- return new CommandJob();
- }
-
- /**
- * Return the title of the job.
- *
- * @return
- */
- public abstract String getJobTitle();
-
- public void init(IWorkbenchWindow window) {
- }
-
- public void run(IAction action) {
- Job job = getJob();
- job.schedule();
- }
-
- public void selectionChanged(IAction action, ISelection selection) {
- this.action = action;
- if (selection instanceof IStructuredSelection) {
- Object sel = ((IStructuredSelection) selection).getFirstElement();
-
- if (sel instanceof IFile) {
- checkEnabled((IFile) sel);
- return;
- }
- }
-
- action.setEnabled(false);
- }
-
-}
\ No newline at end of file
diff --git a/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeBuildRecipeAction.java b/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeBuildRecipeAction.java
deleted file mode 100644
index 22ac94c..0000000
--- a/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeBuildRecipeAction.java
+++ /dev/null
@@ -1,24 +0,0 @@
-/*****************************************************************************
- * 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.yocto.bc.ui.actions;
-
-public class BitbakeBuildRecipeAction extends AbstractBitbakeCommandAction {
-
- @Override
- public String [] getCommands() {
- return new String[] {"bitbake -b " + recipe.getLocationURI().getPath()};
- }
-
- @Override
- public String getJobTitle() {
- return "Building " + recipe.getName();
- }
-}
\ No newline at end of file
diff --git a/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeCleanRecipeAction.java b/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeCleanRecipeAction.java
deleted file mode 100644
index f95117e..0000000
--- a/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeCleanRecipeAction.java
+++ /dev/null
@@ -1,26 +0,0 @@
-/*****************************************************************************
- * 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.yocto.bc.ui.actions;
-
-public class BitbakeCleanRecipeAction extends AbstractBitbakeCommandAction {
-
- @Override
- public String [] getCommands() {
- return new String[] {"bitbake -c clean -b " + recipe.getLocationURI().getPath()};
- }
-
- @Override
- public String getJobTitle() {
- return "Cleaning " + recipe.getName();
- }
-
-
-}
\ No newline at end of file
diff --git a/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeImportAction.java b/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeImportAction.java
deleted file mode 100644
index ecceecf..0000000
--- a/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeImportAction.java
+++ /dev/null
@@ -1,106 +0,0 @@
-/*****************************************************************************
- * 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.yocto.bc.ui.actions;
-
-import java.io.File;
-
-import org.eclipse.core.resources.IProject;
-import org.eclipse.core.resources.IProjectDescription;
-import org.eclipse.core.resources.IResource;
-import org.eclipse.core.resources.IWorkspaceRoot;
-import org.eclipse.core.resources.ResourcesPlugin;
-import org.eclipse.core.runtime.IProgressMonitor;
-import org.eclipse.core.runtime.IStatus; -import org.eclipse.core.runtime.Status; -import org.eclipse.core.runtime.jobs.Job;
-
-import org.yocto.bc.bitbake.BBCommonVars;
-import org.yocto.bc.bitbake.BBRecipe;
-import org.yocto.bc.ui.Activator;
-
-public class BitbakeImportAction extends AbstractBitbakeCommandAction {
-
- private class ImportJob extends Job {
-
- public ImportJob() {
- super(getJobTitle());
- }
-
- @Override
- protected IStatus run(IProgressMonitor monitor) {
-
- try {
- BBRecipe br = new BBRecipe(bbs, recipe.getLocationURI().getPath());
- br.initialize();
- String filePath = (String) br.get(BBCommonVars.S);
-
- //"${WORKDIR}/${PN}-${PV}"
- if (filePath == null) {
- filePath = ((String) br.get(BBCommonVars.WORKDIR)) + File.separator + ((String) br.get(BBCommonVars.PN)) + "-" + ((String) br.get(BBCommonVars.PV));
- }
-
- String projectName = (String) br.get(BBCommonVars.PN);
-
- if (filePath == null || projectName == null) {
- return new Status(IStatus.ERROR, Activator.PLUGIN_ID, "Unable to parse recipe file.");
- }
-
- File workdir = new File(filePath);
-
- if (workdir.exists() && workdir.isFile()) {
- return new Status(IStatus.ERROR, Activator.PLUGIN_ID, workdir.getPath() + " is an invalid workdir.");
- }
-
- if (!workdir.exists()) {
- execCommands(new String[] {"bitbake -c patch -b " + recipe.getLocationURI().getPath()}, monitor);
- }
-
- if (!workdir.exists()) {
- return new Status(IStatus.ERROR, Activator.PLUGIN_ID, "Unable to retrieve sources from BitBake. Consult console.");
- }
-
- IProjectDescription desc = ResourcesPlugin.getWorkspace().newProjectDescription(projectName);
- IWorkspaceRoot wsroot = ResourcesPlugin.getWorkspace().getRoot();
- IProject proj = wsroot.getProject(projectName);
- proj.create(desc, monitor);
- proj.open(monitor);
-
- String copyCmd = "cp -r " + workdir.getAbsolutePath() + File.separator + "* \"" + proj.getLocationURI().getPath() + "\"";
- execCommands(new String[] {copyCmd} , monitor);
-
- proj.refreshLocal(IResource.DEPTH_INFINITE, monitor);
-
- } catch (Exception e) {
- e.printStackTrace();
- return new Status(IStatus.ERROR, Activator.PLUGIN_ID, "Unable to create project.", e);
- }
-
- return Status.OK_STATUS;
- }
-
- }
-
- @Override
- public String [] getCommands() {
- return null;
- }
-
-
- @Override
- public Job getJob() {
- return new ImportJob();
- }
-
- @Override
- public String getJobTitle() {
- return "Importing " + recipe.getName();
- }
-}
\ No newline at end of file
diff --git a/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeRebuildRecipeAction.java b/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeRebuildRecipeAction.java
deleted file mode 100644
index c5dedea..0000000
--- a/plugins/org.yocto.bc.ui/src/org/yocto/bc/ui/actions/BitbakeRebuildRecipeAction.java
+++ /dev/null
@@ -1,29 +0,0 @@
-/*****************************************************************************
- * 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.yocto.bc.ui.actions;
-
-/**
- * Rebuild a recipe.
- * @author kgilmer
- *
- */
-public class BitbakeRebuildRecipeAction extends AbstractBitbakeCommandAction {
-
- @Override
- public String [] getCommands() {
- return new String[] {"bitbake -c rebuild -b " + recipe.getLocationURI().getPath()};
- }
-
- @Override
- public String getJobTitle() {
- return "Rebuilding " + recipe.getName();
- }
-}
\ No newline at end of file
--
1.7.9.5
_______________________________________________
yocto mailing list
yocto at yoctoproject.org
https://lists.yoctoproject.org/listinfo/yocto
More information about the yocto
mailing list