/* cdrdao - write audio CD-Rs in disc-at-once mode * * Copyright (C) 1998-2002 Andreas Mueller * * 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 2 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, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include #include #include #include #include #include #include #include "DeviceList.h" #include "MessageBox.h" #include "xcdrdao.h" #include "Settings.h" #include "CdDevice.h" #include "guiUpdate.h" #include "TocEdit.h" #include "util.h" DeviceList::DeviceList(CdDevice::DeviceType filterType) { Gtk::HBox *hbox; filterType_ = filterType; listModel_ = Gtk::ListStore::create(listColumns_); list_.set_model(listModel_); list_.append_column(_("Vendor"), listColumns_.vendor); list_.append_column(_("Model"), listColumns_.model); list_.append_column(_("Status"), listColumns_.status); Gtk::VBox *contents = new Gtk::VBox; contents->set_spacing(10); // available device list Gtk::HBox *listHBox = new Gtk::HBox; Gtk::VBox *listVBox = new Gtk::VBox; hbox = new Gtk::HBox; hbox->pack_start(list_, TRUE, TRUE); Gtk::Adjustment *adjust = new Gtk::Adjustment(0.0, 0.0, 0.0); Gtk::VScrollbar *scrollBar = new Gtk::VScrollbar(*adjust); hbox->pack_start(*scrollBar, FALSE, FALSE); list_.set_vadjustment(*adjust); listHBox->pack_start(*hbox, TRUE, TRUE, 5); listVBox->pack_start(*listHBox, TRUE, TRUE, 5); switch (filterType_) { case CdDevice::CD_ROM: set_label(_(" Available Reader Devices ")); break; case CdDevice::CD_R: set_label(_(" Available Recorder Devices ")); break; case CdDevice::CD_RW: set_label(_(" Available Recorder (RW) Devices ")); break; } add(*listVBox); } std::string DeviceList::selection() { Gtk::TreeIter i = list_.get_selection()->get_selected(); if (i) { return ((std::string)((*i)[listColumns_.dev])).c_str(); } else return std::string(); } void DeviceList::appendTableEntry(CdDevice *dev) { Gtk::TreeIter newiter = listModel_->append(); Gtk::TreeModel::Row row = *newiter; row[listColumns_.dev] = dev->dev(); row[listColumns_.vendor] = dev->vendor(); row[listColumns_.model] = dev->product(); row[listColumns_.status] = CdDevice::status2string(dev->status()); if (dev->status() == CdDevice::DEV_READY) list_.get_selection()->select(newiter); } void DeviceList::import() { CdDevice *drun; unsigned int i; listModel_->clear(); for (drun = CdDevice::first(); drun != NULL; drun = CdDevice::next(drun)) { switch (filterType_) { case CdDevice::CD_ROM: if (drun->driverId() > 0 && (drun->deviceType() == CdDevice::CD_ROM || drun->deviceType() == CdDevice::CD_R || drun->deviceType() == CdDevice::CD_RW)) { appendTableEntry(drun); } break; case CdDevice::CD_R: if (drun->driverId() > 0 && (drun->deviceType() == CdDevice::CD_R || drun->deviceType() == CdDevice::CD_RW)) { appendTableEntry(drun); } break; case CdDevice::CD_RW: if (drun->driverId() > 0 && (drun->deviceType() == CdDevice::CD_RW)) { appendTableEntry(drun); } break; } } if (listModel_->children().size() > 0) { list_.columns_autosize(); list_.get_selection()->select(Gtk::TreeModel::Path((unsigned)1)); } } void DeviceList::importStatus() { std::string data; CdDevice *cddev; Gtk::TreeNodeChildren ch = listModel_->children(); for (unsigned i = 0; i < ch.size(); i++) { Gtk::TreeRow row = ch[i]; data = row[listColumns_.dev]; if ((cddev = CdDevice::find(data.c_str()))) { if (cddev->status() == CdDevice::DEV_READY) list_.get_column(i)->set_clickable(true); else list_.get_column(i)->set_clickable(false); row[listColumns_.status] = CdDevice::status2string(cddev->status()); } } list_.columns_autosize(); } void DeviceList::selectOne() { if (list_.get_selection()->count_selected_rows() > 0) return; for (unsigned i = 0; i < listModel_->children().size(); i++) { list_.get_selection()->select(Gtk::TreePath(1, i)); if (list_.get_selection()->count_selected_rows() > 0) break; } } void DeviceList::selectOneBut(const char *targetData) { if (!targetData) return selectOne(); if (list_.get_selection()->count_selected_rows() == 0) { Gtk::TreeNodeChildren ch = listModel_->children(); for (unsigned i = 0; i < ch.size(); i++) { std::string sourceData = (ch[i])[listColumns_.dev]; if (sourceData != targetData) { list_.get_selection()->select(ch[i]); break; } } if (list_.get_selection()->count_selected_rows() == 0) { selectOne(); } } }