diff options
author | Timothy Pearson <kb9vqf@pearsoncomputing.net> | 2013-01-27 01:03:37 -0600 |
---|---|---|
committer | Timothy Pearson <kb9vqf@pearsoncomputing.net> | 2013-01-27 01:03:37 -0600 |
commit | 2e25fa39cd67cca2472d3eabdb478feb517d72a5 (patch) | |
tree | 63725962f632d152cbf20709191d39f6fc865966 /kamera/kioslave/kamera.cpp | |
parent | 190d88dfc662f3fc466c9d1f53acbbea65f33c49 (diff) | |
download | tdegraphics-2e25fa39cd67cca2472d3eabdb478feb517d72a5.tar.gz tdegraphics-2e25fa39cd67cca2472d3eabdb478feb517d72a5.zip |
Rename a number of libraries and executables to avoid conflicts with KDE4
Diffstat (limited to 'kamera/kioslave/kamera.cpp')
-rw-r--r-- | kamera/kioslave/kamera.cpp | 1074 |
1 files changed, 0 insertions, 1074 deletions
diff --git a/kamera/kioslave/kamera.cpp b/kamera/kioslave/kamera.cpp deleted file mode 100644 index 9806a132..00000000 --- a/kamera/kioslave/kamera.cpp +++ /dev/null @@ -1,1074 +0,0 @@ -/* - - Copyright (C) 2001 The Kompany - 2001-2003 Ilya Konstantinov <kde-devel@future.shiny.co.il> - 2001-2007 Marcus Meissner <marcus@jet.franken.de> - - 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. - -*/ - -#include <stdlib.h> -#include <unistd.h> -#include <stdio.h> -#include <fcntl.h> -#include <sys/stat.h> -#include <sys/types.h> -#include <signal.h> -#include <errno.h> - -#include <tqfile.h> -#include <tqtextstream.h> - -#include <kdebug.h> -#include <kinstance.h> -#include <kstandarddirs.h> -#include <kconfig.h> -#include <ksimpleconfig.h> -#include <klocale.h> -#include <kprotocolinfo.h> -#include <kio/slaveconfig.h> - -#include <config.h> - -#include "kamera.h" - -#define MAXIDLETIME 30 /* seconds */ - -#define tocstr(x) ((x).local8Bit()) - -using namespace TDEIO; - -extern "C" -{ - KDE_EXPORT int kdemain(int argc, char **argv); - - static void frontendCameraStatus(GPContext *context, const char *format, va_list args, void *data); - static unsigned int frontendProgressStart( - GPContext *context, float totalsize, const char *format, - va_list args, void *data - ); - static void frontendProgressUpdate( - GPContext *context, unsigned int id, float current, void *data - ); -} - -int kdemain(int argc, char **argv) -{ - TDEInstance instance("kio_kamera"); - - if(argc != 4) { - kdDebug(7123) << "Usage: kio_kamera protocol " - "domain-socket1 domain-socket2" << endl; - exit(-1); - } - KameraProtocol slave(argv[2], argv[3]); - slave.dispatchLoop(); - return 0; -} - -KameraProtocol::KameraProtocol(const TQCString &pool, const TQCString &app) -: SlaveBase("camera", pool, app), -m_camera(NULL) -{ - // attempt to initialize libgphoto2 and chosen camera (requires locking) - // (will init m_camera, since the m_camera's configuration is empty) - m_camera = 0; - m_file = NULL; - m_config = new KSimpleConfig(KProtocolInfo::config("camera")); - m_context = gp_context_new(); - actiondone = true; - cameraopen = false; - m_modelSpecified = true; - m_lockfile = locateLocal("tmp", "kamera"); - idletime = 0; -} - -// This handler is getting called every second. We use it to do the -// delayed close of the camera. -// Logic is: -// - No more requests in the queue (signaled by actiondone) AND -// - We are MAXIDLETIME seconds idle OR -// - Another slave wants to have access to the camera. -// -// The existance of a lockfile is used to signify "please give up camera". -// -void KameraProtocol::special(const TQByteArray&) { - kdDebug(7123) << "KameraProtocol::special() at " << getpid() << endl; - - if (!actiondone && cameraopen) { - struct stat stbuf; - if ((-1!=::stat(m_lockfile.utf8(),&stbuf)) || (idletime++ >= MAXIDLETIME)) { - kdDebug(7123) << "KameraProtocol::special() closing camera." << endl; - closeCamera(); - setTimeoutSpecialCommand(-1); - } else { - // continue to wait - setTimeoutSpecialCommand(1); - } - } else { - // We let it run until the slave gets no actions anymore. - setTimeoutSpecialCommand(1); - } - actiondone = false; -} - -KameraProtocol::~KameraProtocol() -{ - kdDebug(7123) << "KameraProtocol::~KameraProtocol()" << endl; - delete m_config; - if(m_camera) { - closeCamera(); - gp_camera_free(m_camera); - m_camera = NULL; - } -} - -// initializes the camera for usage - should be done before operations over the wire -bool KameraProtocol::openCamera(TQString &str) { - idletime = 0; - actiondone = true; - if (!m_camera) { - reparseConfiguration(); - } else { - if (!cameraopen) { - int ret, tries = 15; - kdDebug(7123) << "KameraProtocol::openCamera at " << getpid() << endl; - while (tries--) { - ret = gp_camera_init(m_camera, m_context); - if ( (ret == GP_ERROR_IO_USB_CLAIM) || - (ret == GP_ERROR_IO_LOCK)) { - // just create / touch if not there - int fd = ::open(m_lockfile.utf8(),O_CREAT|O_WRONLY,0600); - if (fd != -1) ::close(fd); - ::sleep(1); - kdDebug(7123) << "openCamera at " << getpid() << "- busy, ret " << ret << ", trying again." << endl; - continue; - } - if (ret == GP_OK) break; - str = gp_result_as_string(ret); - return false; - } - ::unlink(m_lockfile.utf8()); - setTimeoutSpecialCommand(1); - kdDebug(7123) << "openCamera succeeded at " << getpid() << endl; - if (!m_modelSpecified) { - gp_camera_get_abilities(m_camera, &m_abilities); - m_modelSpecified = true; - } - cameraopen = true; - } - } - return true; -} - -// should be done after operations over the wire -void KameraProtocol::closeCamera(void) -{ - int gpr; - - if (!m_camera) - return; - - kdDebug(7123) << "KameraProtocol::closeCamera at " << getpid() << endl; - if ((gpr=gp_camera_exit(m_camera,m_context))!=GP_OK) { - kdDebug(7123) << "closeCamera failed with " << gp_result_as_string(gpr) << endl; - } - // HACK: gp_camera_exit() in gp 2.0 does not close the port if there - // is no camera_exit function. - gp_port_close(m_camera->port); - cameraopen = false; - return; -} - -static TQString fix_foldername(TQString ofolder) { - TQString folder = ofolder; - if (folder.length() > 1) { - while ((folder.length()>1) && (folder.right(1) == "/")) - folder = folder.left(folder.length()-1); - } - if (folder.length() == 0) - folder = "/"; - return folder; -} - -// The KIO slave "get" function (starts a download from the camera) -// The actual returning of the data is done in the frontend callback functions. -void KameraProtocol::get(const KURL &url) -{ - kdDebug(7123) << "KameraProtocol::get(" << url.path() << ")" << endl; - - CameraFileType fileType; - int gpr; - if (url.host().isEmpty()) { - error(TDEIO::ERR_DOES_NOT_EXIST, url.path()); - return; - } - - if(!openCamera()) { - error(TDEIO::ERR_DOES_NOT_EXIST, url.path()); - return; - } - - // fprintf(stderr,"get(%s)\n",url.path().latin1()); - -#define GPHOTO_TEXT_FILE(xx) \ - if (!url.path().compare("/" #xx ".txt")) { \ - CameraText xx; \ - gpr = gp_camera_get_##xx(m_camera, &xx, m_context); \ - if (gpr != GP_OK) { \ - error(TDEIO::ERR_DOES_NOT_EXIST, url.path()); \ - return; \ - } \ - TQByteArray chunkDataBuffer; \ - chunkDataBuffer.setRawData(xx.text, strlen(xx.text)); \ - data(chunkDataBuffer); \ - processedSize(strlen(xx.text)); \ - chunkDataBuffer.resetRawData(xx.text, strlen(xx.text)); \ - finished(); \ - return; \ - } - - GPHOTO_TEXT_FILE(about); - GPHOTO_TEXT_FILE(manual); - GPHOTO_TEXT_FILE(summary); - -#undef GPHOTO_TEXT_FILE - // emit info message - infoMessage( i18n("Retrieving data from camera <b>%1</b>").arg(url.user()) ); - - // Note: There's no need to re-read directory for each get() anymore - gp_file_new(&m_file); - - // emit the total size (we must do it before sending data to allow preview) - CameraFileInfo info; - - gpr = gp_camera_file_get_info(m_camera, tocstr(fix_foldername(url.directory(false))), tocstr(url.fileName()), &info, m_context); - if (gpr != GP_OK) { - // fprintf(stderr,"Folder %s / File %s not found, gpr is %d\n",folder.latin1(), url.fileName().latin1(), gpr); - gp_file_unref(m_file); - if ((gpr == GP_ERROR_FILE_NOT_FOUND) || (gpr == GP_ERROR_DIRECTORY_NOT_FOUND)) - error(TDEIO::ERR_DOES_NOT_EXIST, url.path()); - else - error(TDEIO::ERR_UNKNOWN, gp_result_as_string(gpr)); - return; - } - - // at last, a proper API to determine whether a thumbnail was requested. - if(cameraSupportsPreview() && metaData("thumbnail") == "1") { - kdDebug(7123) << "get() retrieving the thumbnail" << endl; - fileType = GP_FILE_TYPE_PREVIEW; - if (info.preview.fields & GP_FILE_INFO_SIZE) - totalSize(info.preview.size); - if (info.preview.fields & GP_FILE_INFO_TYPE) - mimeType(info.preview.type); - } else { - kdDebug(7123) << "get() retrieving the full-scale photo" << endl; - fileType = GP_FILE_TYPE_NORMAL; - if (info.file.fields & GP_FILE_INFO_SIZE) - totalSize(info.file.size); - if (info.preview.fields & GP_FILE_INFO_TYPE) - mimeType(info.file.type); - } - - // fetch the data - m_fileSize = 0; - gpr = gp_camera_file_get(m_camera, tocstr(fix_foldername(url.directory(false))), tocstr(url.fileName()), fileType, m_file, m_context); - if ( (gpr == GP_ERROR_NOT_SUPPORTED) && - (fileType == GP_FILE_TYPE_PREVIEW) - ) { - // If we get here, the file info command information - // will either not be used, or still valid. - fileType = GP_FILE_TYPE_NORMAL; - gpr = gp_camera_file_get(m_camera, tocstr(fix_foldername(url.directory(false))), tocstr(url.fileName()), fileType, m_file, m_context); - } - switch(gpr) { - case GP_OK: - break; - case GP_ERROR_FILE_NOT_FOUND: - case GP_ERROR_DIRECTORY_NOT_FOUND: - gp_file_unref(m_file); - m_file = NULL; - error(TDEIO::ERR_DOES_NOT_EXIST, url.fileName()); - return ; - default: - gp_file_unref(m_file); - m_file = NULL; - error(TDEIO::ERR_UNKNOWN, gp_result_as_string(gpr)); - return; - } - // emit the mimetype - // NOTE: we must first get the file, so that CameraFile->name would be set - const char *fileMimeType; - gp_file_get_mime_type(m_file, &fileMimeType); - mimeType(fileMimeType); - - // We need to pass left over data here. Some camera drivers do not - // implement progress callbacks! - const char *fileData; - long unsigned int fileSize; - // This merely returns us a pointer to gphoto's internal data - // buffer -- there's no expensive memcpy - gpr = gp_file_get_data_and_size(m_file, &fileData, &fileSize); - if (gpr != GP_OK) { - kdDebug(7123) << "get():: get_data_and_size failed." << endl; - gp_file_free(m_file); - m_file = NULL; - error(TDEIO::ERR_UNKNOWN, gp_result_as_string(gpr)); - return; - } - // make sure we're not sending zero-sized chunks (=EOF) - // also make sure we send only if the progress did not send the data - // already. - if ((fileSize > 0) && (fileSize - m_fileSize)>0) { - unsigned long written = 0; - TQByteArray chunkDataBuffer; - - // We need to split it up here. Someone considered it funny - // to discard any data() larger than 16MB. - // - // So nearly any Movie will just fail.... - while (written < fileSize-m_fileSize) { - unsigned long towrite = 1024*1024; // 1MB - - if (towrite > fileSize-m_fileSize-written) - towrite = fileSize-m_fileSize-written; - chunkDataBuffer.setRawData(fileData + m_fileSize + written, towrite); - processedSize(m_fileSize + written + towrite); - data(chunkDataBuffer); - chunkDataBuffer.resetRawData(fileData + m_fileSize + written, towrite); - written += towrite; - } - m_fileSize = fileSize; - setFileSize(fileSize); - } - - finished(); - gp_file_unref(m_file); /* just unref, might be stored in fs */ - m_file = NULL; -} - -// The KIO slave "stat" function. -void KameraProtocol::stat(const KURL &url) -{ - kdDebug(7123) << "stat(\"" << url.path() << "\")" << endl; - - if (url.path() == "") { - KURL rooturl(url); - - kdDebug(7123) << "redirecting to /" << endl; - rooturl.setPath("/"); - rooturl.setHost(url.host()); - rooturl.setUser(url.user()); - redirection(rooturl); - finished(); - return; - } - - if(url.path() == "/") - statRoot(); - else - statRegular(url); -} - -// Implements stat("/") -- which always returns the same value. -void KameraProtocol::statRoot(void) -{ - UDSEntry entry; - UDSAtom atom; - - atom.m_uds = UDS_NAME; - atom.m_str = "/"; - entry.append(atom); - - atom.m_uds = UDS_FILE_TYPE; - atom.m_long = S_IFDIR; - entry.append(atom); - - atom.m_uds = UDS_ACCESS; - atom.m_long = S_IRUSR | S_IRGRP | S_IROTH | - S_IWUSR | S_IWGRP | S_IWOTH; - entry.append(atom); - - statEntry(entry); - - finished(); - - // This call happens on autodetect by kdemm. So close the camera, but - // only if no more requests are pending. - idletime = MAXIDLETIME; -} - -// Implements a regular stat() of a file / directory, returning all we know about it -void KameraProtocol::statRegular(const KURL &url) -{ - UDSEntry entry; - int gpr; - - kdDebug(7123) << "statRegular(\"" << url.path() << "\")" << endl; - if (openCamera() == false) { - error(TDEIO::ERR_DOES_NOT_EXIST, url.path()); - return; - } - - // fprintf(stderr,"statRegular(%s)\n",url.path().latin1()); - - // Is "url" a directory? - CameraList *dirList; - gp_list_new(&dirList); - kdDebug(7123) << "statRegular() Requesting directories list for " << url.directory() << endl; - - gpr = gp_camera_folder_list_folders(m_camera, tocstr(fix_foldername(url.directory(false))), dirList, m_context); - if (gpr != GP_OK) { - if ((gpr == GP_ERROR_FILE_NOT_FOUND) || (gpr == GP_ERROR_DIRECTORY_NOT_FOUND)) - error(TDEIO::ERR_DOES_NOT_EXIST, url.path()); - else - error(TDEIO::ERR_UNKNOWN, gp_result_as_string(gpr)); - gp_list_free(dirList); - return; - } - -#define GPHOTO_TEXT_FILE(xx) \ - if (!url.path().compare("/"#xx".txt")) { \ - CameraText xx; \ - gpr = gp_camera_get_about(m_camera, &xx, m_context); \ - if (gpr != GP_OK) { \ - error(TDEIO::ERR_DOES_NOT_EXIST, url.fileName()); \ - return; \ - } \ - translateTextToUDS(entry,#xx".txt",xx.text); \ - statEntry(entry); \ - finished(); \ - return; \ - } - GPHOTO_TEXT_FILE(about); - GPHOTO_TEXT_FILE(manual); - GPHOTO_TEXT_FILE(summary); -#undef GPHOTO_TEXT_FILE - - const char *name; - for(int i = 0; i < gp_list_count(dirList); i++) { - gp_list_get_name(dirList, i, &name); - if (url.fileName().compare(name) == 0) { - gp_list_free(dirList); - UDSEntry entry; - translateDirectoryToUDS(entry, url.fileName()); - statEntry(entry); - finished(); - return; - } - } - gp_list_free(dirList); - - // Is "url" a file? - CameraFileInfo info; - gpr = gp_camera_file_get_info(m_camera, tocstr(fix_foldername(url.directory(false))), tocstr(url.fileName()), &info, m_context); - if (gpr != GP_OK) { - if ((gpr == GP_ERROR_FILE_NOT_FOUND) || (gpr == GP_ERROR_DIRECTORY_NOT_FOUND)) - error(TDEIO::ERR_DOES_NOT_EXIST, url.path()); - else - error(TDEIO::ERR_UNKNOWN, gp_result_as_string(gpr)); - return; - } - translateFileToUDS(entry, info, url.fileName()); - statEntry(entry); - finished(); -} - -// The KIO slave "del" function. -void KameraProtocol::del(const KURL &url, bool isFile) -{ - kdDebug(7123) << "KameraProtocol::del(" << url.path() << ")" << endl; - - if(!openCamera()) { - error(TDEIO::ERR_CANNOT_DELETE, url.fileName()); - return; - } - if (!cameraSupportsDel()) { - error(TDEIO::ERR_CANNOT_DELETE, url.fileName()); - return; - } - if(isFile){ - CameraList *list; - gp_list_new(&list); - int ret; - - ret = gp_camera_file_delete(m_camera, tocstr(fix_foldername(url.directory(false))), tocstr(url.fileName()), m_context); - - if(ret != GP_OK) { - error(TDEIO::ERR_CANNOT_DELETE, url.fileName()); - } else { - finished(); - } - } -} - -// The KIO slave "listDir" function. -void KameraProtocol::listDir(const KURL &url) -{ - kdDebug(7123) << "KameraProtocol::listDir(" << url.path() << ")" << endl; - - if (url.host().isEmpty()) { - KURL xurl; - // List the available cameras - TQStringList groupList = m_config->groupList(); - kdDebug(7123) << "Found cameras: " << groupList.join(", ") << endl; - TQStringList::Iterator it; - UDSEntry entry; - UDSAtom atom; - - - /* - * What we do: - * - Autodetect cameras and remember them with their ports. - * - List all saved and possible offline cameras. - * - List all autodetected and not yet printed cameras. - */ - TQMap<TQString,TQString> ports, names; - TQMap<TQString,int> modelcnt; - - /* Autodetect USB cameras ... */ - GPContext *glob_context = NULL; - int i, count; - CameraList *list; - CameraAbilitiesList *al; - GPPortInfoList *il; - - gp_list_new (&list); - gp_abilities_list_new (&al); - gp_abilities_list_load (al, glob_context); - gp_port_info_list_new (&il); - gp_port_info_list_load (il); - gp_abilities_list_detect (al, il, list, glob_context); - gp_abilities_list_free (al); - gp_port_info_list_free (il); - - count = gp_list_count (list); - - for (i = 0 ; i<count ; i++) { - const char *model, *value; - - gp_list_get_name (list, i, &model); - gp_list_get_value (list, i, &value); - - ports[value] = model; - // NOTE: We might get different ports than usb: later! - if (strcmp(value, "usb:")) - names[model] = value; - - /* Save them, even though we can autodetect them for - * offline listing. - */ - m_config->setGroup(model); - m_config->writeEntry("Model",model); - m_config->writeEntry("Path",value); - modelcnt[model]++; - } - gp_list_free (list); - - /* Avoid duplicated entry for usb: and usb:001,042 entries. */ - if (ports.contains("usb:") && names[ports["usb:"]]!="usb:") - ports.remove("usb:"); - - for (it = groupList.begin(); it != groupList.end(); it++) { - TQString m_cfgPath; - if (*it == "<default>") - continue; - - m_config->setGroup(*it); - m_cfgPath = m_config->readEntry("Path"); - - /* If autodetect by USB autodetect ... skip it here. - * We leave unattached USB cameras in here, because the user - * might plug them in later and does not want to press reload. - * We add them with port "usb:". - */ - if (modelcnt[*it] > 0) - continue; - - entry.clear(); - atom.m_uds = UDS_FILE_TYPE;atom.m_long = S_IFDIR;entry.append(atom); - atom.m_uds = UDS_NAME;atom.m_str = *it;entry.append(atom); - atom.m_uds = UDS_ACCESS; - atom.m_long = S_IRUSR | S_IRGRP | S_IROTH | - S_IWUSR | S_IWGRP | S_IWOTH; - entry.append(atom); - - atom.m_uds = UDS_URL; - - xurl.setProtocol("camera"); - xurl.setUser(*it); - /* Avoid setting usb:xxx,yyy. */ - if (m_cfgPath.contains("usb:")>0) { - names[*it] = "usb:"; - xurl.setHost("usb:"); - } else { - xurl.setHost(m_cfgPath); - } - xurl.setPath("/"); - atom.m_str = xurl.url(); - entry.append(atom); - - listEntry(entry, false); - } - - TQMap<TQString,TQString>::iterator portsit; - - for (portsit = ports.begin(); portsit != ports.end(); portsit++) { - entry.clear(); - atom.m_uds = UDS_FILE_TYPE;atom.m_long = S_IFDIR; entry.append(atom); - atom.m_uds = UDS_NAME;atom.m_str = portsit.data();entry.append(atom); - - atom.m_uds = UDS_ACCESS; - atom.m_long = S_IRUSR | S_IRGRP | S_IROTH | - S_IWUSR | S_IWGRP | S_IWOTH; - entry.append(atom); - - atom.m_uds = UDS_URL; - xurl.setProtocol("camera"); - xurl.setHost(portsit.key()); - xurl.setUser(portsit.data()); - xurl.setPath("/"); - atom.m_str = xurl.url(); - entry.append(atom); - - listEntry(entry, false); - } - listEntry(entry, true); - - finished(); - return; - } - - if (url.path() == "") { - KURL rooturl(url); - - kdDebug(7123) << "redirecting to /" << endl; - rooturl.setPath("/"); - rooturl.setHost(url.host()); - rooturl.setUser(url.user()); - redirection(rooturl); - finished(); - return; - } - - if (!openCamera()) { - error(TDEIO::ERR_COULD_NOT_READ,url.path()); - return; - } - - CameraList *dirList; - CameraList *fileList; - CameraList *specialList; - gp_list_new(&dirList); - gp_list_new(&fileList); - gp_list_new(&specialList); - int gpr; - - if (!url.path().compare("/")) { - CameraText text; - if (GP_OK == gp_camera_get_manual(m_camera, &text, m_context)) - gp_list_append(specialList,"manual.txt",NULL); - if (GP_OK == gp_camera_get_about(m_camera, &text, m_context)) - gp_list_append(specialList,"about.txt",NULL); - if (GP_OK == gp_camera_get_summary(m_camera, &text, m_context)) - gp_list_append(specialList,"summary.txt",NULL); - } - - gpr = readCameraFolder(url.path(), dirList, fileList); - if(gpr != GP_OK) { - kdDebug(7123) << "read Camera Folder failed:" << gp_result_as_string(gpr) <<endl; - gp_list_free(dirList); - gp_list_free(fileList); - gp_list_free(specialList); - error(TDEIO::ERR_COULD_NOT_READ, gp_result_as_string(gpr)); - return; - } - - totalSize(gp_list_count(specialList) + gp_list_count(dirList) + gp_list_count(fileList)); - - UDSEntry entry; - const char *name; - - for(int i = 0; i < gp_list_count(dirList); ++i) { - gp_list_get_name(dirList, i, &name); - translateDirectoryToUDS(entry, TQString::fromLocal8Bit(name)); - listEntry(entry, false); - } - - CameraFileInfo info; - - for(int i = 0; i < gp_list_count(fileList); ++i) { - gp_list_get_name(fileList, i, &name); - // we want to know more info about files (size, type...) - gp_camera_file_get_info(m_camera, tocstr(url.path()), name, &info, m_context); - translateFileToUDS(entry, info, TQString::fromLocal8Bit(name)); - listEntry(entry, false); - } - if (!url.path().compare("/")) { - CameraText text; - if (GP_OK == gp_camera_get_manual(m_camera, &text, m_context)) { - translateTextToUDS(entry, "manual.txt", text.text); - listEntry(entry, false); - } - if (GP_OK == gp_camera_get_about(m_camera, &text, m_context)) { - translateTextToUDS(entry, "about.txt", text.text); - listEntry(entry, false); - } - if (GP_OK == gp_camera_get_summary(m_camera, &text, m_context)) { - translateTextToUDS(entry, "summary.txt", text.text); - listEntry(entry, false); - } - } - - - gp_list_free(fileList); - gp_list_free(dirList); - gp_list_free(specialList); - - listEntry(entry, true); // 'entry' is not used in this case - we only signal list completion - finished(); -} - -void KameraProtocol::setHost(const TQString& host, int port, const TQString& user, const TQString& pass ) -{ - kdDebug(7123) << "KameraProtocol::setHost(" << host << ", " << port << ", " << user << ", " << pass << ")" << endl; - int gpr, idx; - - if (!host.isEmpty()) { - kdDebug(7123) << "model is " << user << ", port is " << host << endl; - if (m_camera) { - kdDebug(7123) << "Configuration change detected" << endl; - closeCamera(); - gp_camera_unref(m_camera); - m_camera = NULL; - infoMessage( i18n("Reinitializing camera") ); - } else { - kdDebug(7123) << "Initializing camera" << endl; - infoMessage( i18n("Initializing camera") ); - } - // fetch abilities - CameraAbilitiesList *abilities_list; - gp_abilities_list_new(&abilities_list); - gp_abilities_list_load(abilities_list, m_context); - idx = gp_abilities_list_lookup_model(abilities_list, tocstr(user)); - if (idx < 0) { - gp_abilities_list_free(abilities_list); - kdDebug(7123) << "Unable to get abilities for model: " << user << ", falling back to automatic model detection" << endl; - m_modelSpecified = false; - } - if (m_modelSpecified) { - gp_abilities_list_get_abilities(abilities_list, idx, &m_abilities); - gp_abilities_list_free(abilities_list); - } - - // fetch port - GPPortInfoList *port_info_list; - GPPortInfo port_info; - gp_port_info_list_new(&port_info_list); - gp_port_info_list_load(port_info_list); - idx = gp_port_info_list_lookup_path(port_info_list, tocstr(host)); - - /* Handle erronously passed usb:XXX,YYY */ - if ((idx < 0) && host.startsWith("usb:")) - idx = gp_port_info_list_lookup_path(port_info_list, "usb:"); - if (idx < 0) { - gp_port_info_list_free(port_info_list); - kdDebug(7123) << "Unable to get port info for path: " << host << endl; - error(TDEIO::ERR_UNKNOWN, gp_result_as_string(idx)); - return; - } - gp_port_info_list_get_info(port_info_list, idx, &port_info); - gp_port_info_list_free(port_info_list); - - // create a new camera object - gpr = gp_camera_new(&m_camera); - if(gpr != GP_OK) { - error(TDEIO::ERR_UNKNOWN, gp_result_as_string(gpr)); - return; - } - - // register gphoto2 callback functions - gp_context_set_status_func(m_context, frontendCameraStatus, this); - gp_context_set_progress_funcs(m_context, frontendProgressStart, frontendProgressUpdate, NULL, this); - // gp_camera_set_message_func(m_camera, ..., this) - - // set model and port - if (m_modelSpecified) { - gp_camera_set_abilities(m_camera, m_abilities); - } - gp_camera_set_port_info(m_camera, port_info); - gp_camera_set_port_speed(m_camera, 0); // TODO: the value needs to be configurable - kdDebug(7123) << "Opening camera model " << user << " at " << host << endl; - - TQString errstr; - if (!openCamera(errstr)) { - kdDebug(7123) << "Unable to init camera: " << gp_result_as_string(gpr) << endl; - error(TDEIO::ERR_SERVICE_NOT_AVAILABLE, errstr); - gp_camera_exit(m_camera, m_context); - return; - } - } -} - -void KameraProtocol::reparseConfiguration(void) -{ - // we have no global config, do we? -} - -// translate a simple text to a UDS entry -void KameraProtocol::translateTextToUDS(UDSEntry &udsEntry, const TQString &fn, - const char *text -) { - UDSAtom atom; - - udsEntry.clear(); - - atom.m_uds = UDS_FILE_TYPE; // UDS type - atom.m_long = S_IFREG; // file - udsEntry.append(atom); - - atom.m_uds = UDS_NAME; - atom.m_str = fn; - udsEntry.append(atom); - - atom.m_uds = UDS_SIZE; - atom.m_long = strlen(text); - udsEntry.append(atom); - - atom.m_uds = UDS_ACCESS; - atom.m_long = S_IRUSR | S_IRGRP | S_IROTH; - udsEntry.append(atom); -} - -// translate a CameraFileInfo to a UDSEntry which we can return as a directory listing entry -void KameraProtocol::translateFileToUDS(UDSEntry &udsEntry, const CameraFileInfo &info, TQString name) -{ - UDSAtom atom; - - udsEntry.clear(); - - atom.m_uds = UDS_FILE_TYPE; // UDS type - atom.m_long = S_IFREG; // file - udsEntry.append(atom); - - atom.m_uds = UDS_NAME; - if (info.file.fields & GP_FILE_INFO_NAME) - atom.m_str = TQString::fromLocal8Bit(info.file.name); - else - atom.m_str = name; - udsEntry.append(atom); - - if (info.file.fields & GP_FILE_INFO_SIZE) { - atom.m_uds = UDS_SIZE; - atom.m_long = info.file.size; - udsEntry.append(atom); - } - - if (info.file.fields & GP_FILE_INFO_MTIME) { - atom.m_uds = UDS_MODIFICATION_TIME; - atom.m_long = info.file.mtime; - udsEntry.append(atom); - } else { - atom.m_uds = UDS_MODIFICATION_TIME; - atom.m_long = time(NULL); /* NOW */ - udsEntry.append(atom); - } - - if (info.file.fields & GP_FILE_INFO_TYPE) { - atom.m_uds = UDS_MIME_TYPE; - atom.m_str = TQString::fromLatin1(info.file.type); - udsEntry.append(atom); - } - - if (info.file.fields & GP_FILE_INFO_PERMISSIONS) { - atom.m_uds = UDS_ACCESS; - atom.m_long = 0; - atom.m_long |= (info.file.permissions & GP_FILE_PERM_READ) ? (S_IRUSR | S_IRGRP | S_IROTH) : 0; - // we cannot represent individual FP_FILE_PERM_DELETE permission in the Unix access scheme - // since the parent directory's write permission defines that - udsEntry.append(atom); - } else { - // basic permissions, in case the camera doesn't provide permissions info - atom.m_uds = UDS_ACCESS; - atom.m_long = S_IRUSR | S_IRGRP | S_IROTH; - udsEntry.append(atom); - } - - // TODO: We do not handle info.preview in any way -} - -// translate a directory name to a UDSEntry which we can return as a directory listing entry -void KameraProtocol::translateDirectoryToUDS(UDSEntry &udsEntry, const TQString &dirname) -{ - UDSAtom atom; - - udsEntry.clear(); - - atom.m_uds = UDS_FILE_TYPE; // UDS type - atom.m_long = S_IFDIR; // directory - udsEntry.append(atom); - - atom.m_uds = UDS_NAME; - atom.m_str = dirname; - udsEntry.append(atom); - - atom.m_uds = UDS_ACCESS; - atom.m_long = S_IRUSR | S_IRGRP | S_IROTH | - S_IWUSR | S_IWGRP | S_IWOTH; - udsEntry.append(atom); - - atom.m_uds = UDS_MIME_TYPE; - atom.m_str = "inode/directory"; - udsEntry.append(atom); -} - -bool KameraProtocol::cameraSupportsDel(void) -{ - return (m_abilities.file_operations & GP_FILE_OPERATION_DELETE); -} - -bool KameraProtocol::cameraSupportsPut(void) -{ - return (m_abilities.folder_operations & GP_FOLDER_OPERATION_PUT_FILE); -} - -bool KameraProtocol::cameraSupportsPreview(void) -{ - return (m_abilities.file_operations & GP_FILE_OPERATION_PREVIEW); -} - -int KameraProtocol::readCameraFolder(const TQString &folder, CameraList *dirList, CameraList *fileList) -{ - kdDebug(7123) << "KameraProtocol::readCameraFolder(" << folder << ")" << endl; - - int gpr; - if((gpr = gp_camera_folder_list_folders(m_camera, tocstr(folder), dirList, m_context)) != GP_OK) - return gpr; - if((gpr = gp_camera_folder_list_files(m_camera, tocstr(folder), fileList, m_context)) != GP_OK) - return gpr; - return GP_OK; -} - -void frontendProgressUpdate( - GPContext * /*context*/, unsigned int /*id*/, float /*current*/, void *data -) { - KameraProtocol *object = (KameraProtocol*)data; - - // This code will get the last chunk of data retrieved from the - // camera and pass it to KIO, to allow progressive display - // of the downloaded photo. - - const char *fileData = NULL; - long unsigned int fileSize = 0; - - // This merely returns us a pointer to gphoto's internal data - // buffer -- there's no expensive memcpy - if (!object->getFile()) - return; - gp_file_get_data_and_size(object->getFile(), &fileData, &fileSize); - // make sure we're not sending zero-sized chunks (=EOF) - if (fileSize > 0) { - // XXX using assign() here causes segfault, prolly because - // gp_file_free is called before chunkData goes out of scope - TQByteArray chunkDataBuffer; - chunkDataBuffer.setRawData(fileData + object->getFileSize(), fileSize - object->getFileSize()); - // Note: this will fail with sizes > 16MB ... - object->data(chunkDataBuffer); - object->processedSize(fileSize); - chunkDataBuffer.resetRawData(fileData + object->getFileSize(), fileSize - object->getFileSize()); - object->setFileSize(fileSize); - } -} - -unsigned int frontendProgressStart( - GPContext * /*context*/, float totalsize, const char *format, va_list args, - void *data -) { - KameraProtocol *object = (KameraProtocol*)data; - char *status; - - /* We must copy the va_list to walk it twice, or all hell - * breaks loose on non-i386 platforms. - */ -#if defined(HAVE_VA_COPY) || defined(HAVE___VA_COPY) - va_list xvalist; -# ifdef HAVE_VA_COPY - va_copy(xvalist, args); -# elif HAVE___VA_COPY - __va_copy(xvalist, args); -# endif - int size=vsnprintf(NULL, 0, format, xvalist); - if(size<=0) - return GP_OK; // vsnprintf is broken, better don't do anything. - - status=new char[size+1]; -# ifdef HAVE_VA_COPY - va_copy(xvalist, args); -# elif HAVE___VA_COPY - __va_copy(xvalist, args); -# endif - vsnprintf(status, size+1, format, xvalist); -#else - /* We cannot copy the va_list, so make sure we - * walk it just _once_. - */ - status=new char[300]; - vsnprintf(status, 300, format, args); -#endif - - object->infoMessage(TQString::fromLocal8Bit(status)); - delete [] status; - object->totalSize((int)totalsize); // hack: call slot directly - return GP_OK; -} - -// this callback function is activated on every status message from gphoto2 -static void frontendCameraStatus(GPContext * /*context*/, const char *format, va_list args, void *data) -{ - KameraProtocol *object = (KameraProtocol*)data; - char *status; - - /* We must copy the va_list to walk it twice, or all hell - * breaks loose on non-i386 platforms. - */ -#if defined(HAVE_VA_COPY) || defined(HAVE___VA_COPY) - va_list xvalist; -# ifdef HAVE_VA_COPY - va_copy(xvalist, args); -# elif HAVE___VA_COPY - __va_copy(xvalist, args); -# endif - int size=vsnprintf(NULL, 0, format, xvalist); - if(size<=0) - return; // vsnprintf is broken, better don't do anything. - - status=new char[size+1]; -# ifdef HAVE_VA_COPY - va_copy(xvalist, args); -# elif HAVE___VA_COPY - __va_copy(xvalist, args); -# endif - vsnprintf(status, size+1, format, xvalist); -#else - /* We cannot copy the va_list, so make sure we - * walk it just _once_. - */ - status=new char[300]; - vsnprintf(status, 300, format, args); -#endif - object->infoMessage(TQString::fromLocal8Bit(status)); - delete [] status; -} |