/* * DBeaver - Universal Database Manager * Copyright (C) 2010-2017 Serge Rider (serge@jkiss.org) * Copyright (C) 2011-2012 Eugene Fradkin (eugene.fradkin@gmail.com) * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.jkiss.dbeaver.ext.mysql.tools.maintenance; import org.eclipse.swt.SWT; import org.eclipse.swt.layout.GridData; import org.eclipse.swt.widgets.Combo; import org.eclipse.swt.widgets.Composite; import org.eclipse.swt.widgets.Group; import org.eclipse.ui.IWorkbenchPart; import org.eclipse.ui.IWorkbenchPartSite; import org.eclipse.ui.IWorkbenchWindow; import org.jkiss.dbeaver.DBException; import org.jkiss.dbeaver.ext.mysql.model.MySQLTable; import org.jkiss.dbeaver.model.DBPEvaluationContext; import org.jkiss.dbeaver.model.struct.DBSObject; import org.jkiss.dbeaver.tools.IExternalTool; import org.jkiss.dbeaver.ui.UIUtils; import org.jkiss.utils.CommonUtils; import java.util.Collection; import java.util.List; /** * Table check */ public class MySQLToolCheck implements IExternalTool { @Override public void execute(IWorkbenchWindow window, IWorkbenchPart activePart, Collection<DBSObject> objects) throws DBException { List<MySQLTable> tables = CommonUtils.filterCollection(objects, MySQLTable.class); if (!tables.isEmpty()) { SQLDialog dialog = new SQLDialog(activePart.getSite(), tables); dialog.open(); } } static class SQLDialog extends TableToolDialog { private Combo optionCombo; public SQLDialog(IWorkbenchPartSite partSite, Collection<MySQLTable> selectedTables) { super(partSite, "Check table(s)", selectedTables); } @Override protected void generateObjectCommand(List<String> lines, MySQLTable object) { String sql = "CHECK TABLE " + object.getFullyQualifiedName(DBPEvaluationContext.DDL); String option = optionCombo.getText(); if (!CommonUtils.isEmpty(option)) sql += " " + option; lines.add(sql); } @Override protected void createControls(Composite parent) { Group optionsGroup = UIUtils.createControlGroup(parent, "Options", 1, 0, 0); optionsGroup.setLayoutData(new GridData(GridData.FILL_HORIZONTAL)); optionCombo = UIUtils.createLabelCombo(optionsGroup, "Option", SWT.DROP_DOWN | SWT.READ_ONLY); optionCombo.add(""); optionCombo.add("FOR UPGRADE"); optionCombo.add("QUICK"); optionCombo.add("FAST"); optionCombo.add("MEDIUM"); optionCombo.add("EXTENDED"); optionCombo.add("CHANGED"); optionCombo.addSelectionListener(SQL_CHANGE_LISTENER); createObjectsSelector(parent); } } }