417 lines
13 KiB
Diff
417 lines
13 KiB
Diff
|
diff -ru libgphoto2-2.4.9/camlibs/ptp2/config.c libgphoto2//camlibs/ptp2/config.c
|
||
|
--- libgphoto2-2.4.9/camlibs/ptp2/config.c 2010-04-11 14:17:51.000000000 +0200
|
||
|
+++ libgphoto2//camlibs/ptp2/config.c 2010-06-17 17:05:11.989020000 +0200
|
||
|
@@ -510,6 +524,7 @@
|
||
|
static int
|
||
|
_get_Generic16Table(CONFIG_GET_ARGS, struct deviceproptableu16* tbl, int tblsize) {
|
||
|
int i, j;
|
||
|
+ int isset = FALSE, isset2 = FALSE;
|
||
|
|
||
|
if (!(dpd->FormFlag & (PTP_DPFF_Enumeration|PTP_DPFF_Range))) {
|
||
|
gp_log (GP_LOG_DEBUG, "ptp/get_generic16", "no enumeration/range in 16bit table code");
|
||
|
@@ -537,16 +552,16 @@
|
||
|
return GP_OK;
|
||
|
}
|
||
|
for (i = 0; i<dpd->FORM.Enum.NumberOfValues; i++) {
|
||
|
- int isset = FALSE;
|
||
|
-
|
||
|
for (j=0;j<tblsize;j++) {
|
||
|
if ((tbl[j].value == dpd->FORM.Enum.SupportedValue[i].u16) &&
|
||
|
((tbl[j].vendor_id == 0) ||
|
||
|
(tbl[j].vendor_id == camera->pl->params.deviceinfo.VendorExtensionID))
|
||
|
) {
|
||
|
gp_widget_add_choice (*widget, _(tbl[j].label));
|
||
|
- if (tbl[j].value == dpd->CurrentValue.u16)
|
||
|
+ if (tbl[j].value == dpd->CurrentValue.u16) {
|
||
|
+ isset2 = TRUE;
|
||
|
gp_widget_set_value (*widget, _(tbl[j].label));
|
||
|
+ }
|
||
|
isset = TRUE;
|
||
|
break;
|
||
|
}
|
||
|
@@ -555,8 +570,10 @@
|
||
|
char buf[200];
|
||
|
sprintf(buf, _("Unknown value %04x"), dpd->FORM.Enum.SupportedValue[i].u16);
|
||
|
gp_widget_add_choice (*widget, buf);
|
||
|
- if (dpd->FORM.Enum.SupportedValue[i].u16 == dpd->CurrentValue.u16)
|
||
|
+ if (dpd->FORM.Enum.SupportedValue[i].u16 == dpd->CurrentValue.u16) {
|
||
|
+ isset2 = TRUE;
|
||
|
gp_widget_set_value (*widget, buf);
|
||
|
+ }
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
@@ -565,16 +582,16 @@
|
||
|
i<=dpd->FORM.Range.MaximumValue.u16;
|
||
|
i+= dpd->FORM.Range.StepSize.u16
|
||
|
) {
|
||
|
- int isset = FALSE;
|
||
|
-
|
||
|
for (j=0;j<tblsize;j++) {
|
||
|
if ((tbl[j].value == i) &&
|
||
|
((tbl[j].vendor_id == 0) ||
|
||
|
(tbl[j].vendor_id == camera->pl->params.deviceinfo.VendorExtensionID))
|
||
|
) {
|
||
|
gp_widget_add_choice (*widget, _(tbl[j].label));
|
||
|
- if (i == dpd->CurrentValue.u16)
|
||
|
+ if (i == dpd->CurrentValue.u16) {
|
||
|
+ isset2 = TRUE;
|
||
|
gp_widget_set_value (*widget, _(tbl[j].label));
|
||
|
+ }
|
||
|
isset = TRUE;
|
||
|
break;
|
||
|
}
|
||
|
@@ -583,11 +600,19 @@
|
||
|
char buf[200];
|
||
|
sprintf(buf, _("Unknown value %04d"), i);
|
||
|
gp_widget_add_choice (*widget, buf);
|
||
|
- if (i == dpd->CurrentValue.u16)
|
||
|
+ if (i == dpd->CurrentValue.u16) {
|
||
|
+ isset2 = TRUE;
|
||
|
gp_widget_set_value (*widget, buf);
|
||
|
+ }
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
+ if (!isset2) {
|
||
|
+ char buf[200];
|
||
|
+ sprintf(buf, _("Unknown value %04x"), dpd->CurrentValue.u16);
|
||
|
+ gp_widget_add_choice (*widget, buf);
|
||
|
+ gp_widget_set_value (*widget, buf);
|
||
|
+ }
|
||
|
return (GP_OK);
|
||
|
}
|
||
|
|
||
|
@@ -634,6 +659,7 @@
|
||
|
static int
|
||
|
_get_GenericI16Table(CONFIG_GET_ARGS, struct deviceproptablei16* tbl, int tblsize) {
|
||
|
int i, j;
|
||
|
+ int isset = FALSE, isset2 = FALSE;
|
||
|
|
||
|
if (!(dpd->FormFlag & (PTP_DPFF_Range|PTP_DPFF_Enumeration))) {
|
||
|
gp_log (GP_LOG_DEBUG, "ptp/get_generici16", "no enumeration/range in 16bit table code");
|
||
|
@@ -661,16 +687,16 @@
|
||
|
return GP_OK;
|
||
|
}
|
||
|
for (i = 0; i<dpd->FORM.Enum.NumberOfValues; i++) {
|
||
|
- int isset = FALSE;
|
||
|
-
|
||
|
for (j=0;j<tblsize;j++) {
|
||
|
if ((tbl[j].value == dpd->FORM.Enum.SupportedValue[i].i16) &&
|
||
|
((tbl[j].vendor_id == 0) ||
|
||
|
(tbl[j].vendor_id == camera->pl->params.deviceinfo.VendorExtensionID))
|
||
|
) {
|
||
|
gp_widget_add_choice (*widget, _(tbl[j].label));
|
||
|
- if (tbl[j].value == dpd->CurrentValue.i16)
|
||
|
+ if (tbl[j].value == dpd->CurrentValue.i16) {
|
||
|
gp_widget_set_value (*widget, _(tbl[j].label));
|
||
|
+ isset2 = TRUE;
|
||
|
+ }
|
||
|
isset = TRUE;
|
||
|
break;
|
||
|
}
|
||
|
@@ -694,8 +720,10 @@
|
||
|
(tbl[j].vendor_id == camera->pl->params.deviceinfo.VendorExtensionID))
|
||
|
) {
|
||
|
gp_widget_add_choice (*widget, _(tbl[j].label));
|
||
|
- if (i == dpd->CurrentValue.i16)
|
||
|
+ if (i == dpd->CurrentValue.i16) {
|
||
|
+ isset2 = TRUE;
|
||
|
gp_widget_set_value (*widget, _(tbl[j].label));
|
||
|
+ }
|
||
|
isset = TRUE;
|
||
|
break;
|
||
|
}
|
||
|
@@ -704,11 +732,19 @@
|
||
|
char buf[200];
|
||
|
sprintf(buf, _("Unknown value %04d"), i);
|
||
|
gp_widget_add_choice (*widget, buf);
|
||
|
- if (i == dpd->CurrentValue.i16)
|
||
|
+ if (i == dpd->CurrentValue.i16) {
|
||
|
+ isset2 = TRUE;
|
||
|
gp_widget_set_value (*widget, buf);
|
||
|
+ }
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
+ if (!isset2) {
|
||
|
+ char buf[200];
|
||
|
+ sprintf(buf, _("Unknown value %04x"), dpd->CurrentValue.i16);
|
||
|
+ gp_widget_add_choice (*widget, buf);
|
||
|
+ gp_widget_set_value (*widget, buf);
|
||
|
+ }
|
||
|
return (GP_OK);
|
||
|
}
|
||
|
|
||
|
@@ -755,6 +791,7 @@
|
||
|
static int
|
||
|
_get_Generic8Table(CONFIG_GET_ARGS, struct deviceproptableu8* tbl, int tblsize) {
|
||
|
int i, j;
|
||
|
+ int isset = FALSE, isset2 = FALSE;
|
||
|
|
||
|
if (dpd->FormFlag & PTP_DPFF_Enumeration) {
|
||
|
if (dpd->DataType != PTP_DTC_UINT8)
|
||
|
@@ -762,16 +799,16 @@
|
||
|
gp_widget_new (GP_WIDGET_RADIO, _(menu->label), widget);
|
||
|
gp_widget_set_name (*widget, menu->name);
|
||
|
for (i = 0; i<dpd->FORM.Enum.NumberOfValues; i++) {
|
||
|
- int isset = FALSE;
|
||
|
-
|
||
|
for (j=0;j<tblsize;j++) {
|
||
|
if ((tbl[j].value == dpd->FORM.Enum.SupportedValue[i].u8) &&
|
||
|
((tbl[j].vendor_id == 0) ||
|
||
|
(tbl[j].vendor_id == camera->pl->params.deviceinfo.VendorExtensionID))
|
||
|
) {
|
||
|
gp_widget_add_choice (*widget, _(tbl[j].label));
|
||
|
- if (tbl[j].value == dpd->CurrentValue.u8)
|
||
|
+ if (tbl[j].value == dpd->CurrentValue.u8) {
|
||
|
+ isset2 = TRUE;
|
||
|
gp_widget_set_value (*widget, _(tbl[j].label));
|
||
|
+ }
|
||
|
isset = TRUE;
|
||
|
break;
|
||
|
}
|
||
|
@@ -784,6 +821,12 @@
|
||
|
gp_widget_set_value (*widget, buf);
|
||
|
}
|
||
|
}
|
||
|
+ if (!isset2) {
|
||
|
+ char buf[200];
|
||
|
+ sprintf(buf, _("Unknown value %04x"), dpd->CurrentValue.u8);
|
||
|
+ gp_widget_add_choice (*widget, buf);
|
||
|
+ gp_widget_set_value (*widget, buf);
|
||
|
+ }
|
||
|
return (GP_OK);
|
||
|
}
|
||
|
if (dpd->FormFlag & PTP_DPFF_Range) {
|
||
|
@@ -795,16 +838,16 @@
|
||
|
i <= dpd->FORM.Range.MaximumValue.u8;
|
||
|
i+= dpd->FORM.Range.StepSize.u8
|
||
|
) {
|
||
|
- int isset = FALSE;
|
||
|
-
|
||
|
for (j=0;j<tblsize;j++) {
|
||
|
if ((tbl[j].value == i) &&
|
||
|
((tbl[j].vendor_id == 0) ||
|
||
|
(tbl[j].vendor_id == camera->pl->params.deviceinfo.VendorExtensionID))
|
||
|
) {
|
||
|
gp_widget_add_choice (*widget, _(tbl[j].label));
|
||
|
- if (tbl[j].value == dpd->CurrentValue.u8)
|
||
|
+ if (tbl[j].value == dpd->CurrentValue.u8) {
|
||
|
+ isset2 = TRUE;
|
||
|
gp_widget_set_value (*widget, _(tbl[j].label));
|
||
|
+ }
|
||
|
isset = TRUE;
|
||
|
break;
|
||
|
}
|
||
|
@@ -813,10 +856,18 @@
|
||
|
char buf[200];
|
||
|
sprintf(buf, _("Unknown value %04x"), i);
|
||
|
gp_widget_add_choice (*widget, buf);
|
||
|
- if (i == dpd->CurrentValue.u8)
|
||
|
+ if (i == dpd->CurrentValue.u8) {
|
||
|
+ isset2 = TRUE;
|
||
|
gp_widget_set_value (*widget, buf);
|
||
|
+ }
|
||
|
}
|
||
|
}
|
||
|
+ if (!isset2) {
|
||
|
+ char buf[200];
|
||
|
+ sprintf(buf, _("Unknown value %04x"), dpd->CurrentValue.u8);
|
||
|
+ gp_widget_add_choice (*widget, buf);
|
||
|
+ gp_widget_set_value (*widget, buf);
|
||
|
+ }
|
||
|
return (GP_OK);
|
||
|
}
|
||
|
return (GP_ERROR);
|
||
|
@@ -3367,7 +3418,12 @@
|
||
|
return GP_ERROR;
|
||
|
}
|
||
|
/* Get the next set of event data */
|
||
|
- return _ptp_check_eos_events (params);
|
||
|
+ ret = _ptp_check_eos_events (params);
|
||
|
+ if (ret != PTP_RC_OK) {
|
||
|
+ gp_log (GP_LOG_ERROR,"ptp2/canon_eos_afdrive", "getevent failed!");
|
||
|
+ return translate_ptp_result (ret);
|
||
|
+ }
|
||
|
+ return GP_OK;
|
||
|
}
|
||
|
|
||
|
static int
|
||
|
@@ -3450,7 +3506,92 @@
|
||
|
return GP_ERROR;
|
||
|
}
|
||
|
/* Get the next set of event data */
|
||
|
- return _ptp_check_eos_events (params);
|
||
|
+ ret = _ptp_check_eos_events (params);
|
||
|
+ if (ret != PTP_RC_OK) {
|
||
|
+ gp_log (GP_LOG_ERROR,"ptp2/canon_eos_mfdrive", "getevent failed!");
|
||
|
+ return translate_ptp_result (ret);
|
||
|
+ }
|
||
|
+ return GP_OK;
|
||
|
+}
|
||
|
+
|
||
|
+
|
||
|
+static int
|
||
|
+_get_Canon_EOS_Zoom(CONFIG_GET_ARGS) {
|
||
|
+ gp_widget_new (GP_WIDGET_TEXT, _(menu->label), widget);
|
||
|
+ gp_widget_set_name (*widget, menu->name);
|
||
|
+
|
||
|
+ gp_widget_set_value (*widget, "0");
|
||
|
+ return (GP_OK);
|
||
|
+}
|
||
|
+
|
||
|
+/* Only 1 and 5 seem to work on the EOS 1000D */
|
||
|
+static int
|
||
|
+_put_Canon_EOS_Zoom(CONFIG_PUT_ARGS) {
|
||
|
+ uint16_t ret;
|
||
|
+ const char* val;
|
||
|
+ unsigned int xval;
|
||
|
+ PTPParams *params = &(camera->pl->params);
|
||
|
+
|
||
|
+ if (!ptp_operation_issupported(params, PTP_OC_CANON_EOS_Zoom))
|
||
|
+ return (GP_ERROR_NOT_SUPPORTED);
|
||
|
+
|
||
|
+ gp_widget_get_value(widget, &val);
|
||
|
+ if (!sscanf (val, "%d", &xval)) {
|
||
|
+ gp_log (GP_LOG_DEBUG, "ptp2/canon_eos_zoom", "Could not parse %s", val);
|
||
|
+ return GP_ERROR;
|
||
|
+ }
|
||
|
+ ret = ptp_canon_eos_zoom (params, xval);
|
||
|
+ if (ret != PTP_RC_OK) {
|
||
|
+ gp_log (GP_LOG_DEBUG, "ptp2/canon_eos_zoom", "Canon zoom 0x%x failed: 0x%x", xval, ret);
|
||
|
+ return GP_ERROR;
|
||
|
+ }
|
||
|
+ /* Get the next set of event data */
|
||
|
+ ret = _ptp_check_eos_events (params);
|
||
|
+ if (ret != PTP_RC_OK) {
|
||
|
+ gp_log (GP_LOG_ERROR,"ptp2/canon_eos_zoom", "getevent failed!");
|
||
|
+ return translate_ptp_result (ret);
|
||
|
+ }
|
||
|
+ return GP_OK;
|
||
|
+}
|
||
|
+
|
||
|
+/* EOS Zoom. Works in approx 64 pixel steps on the EOS 1000D, but just accept
|
||
|
+ * all kind of pairs */
|
||
|
+static int
|
||
|
+_get_Canon_EOS_ZoomPosition(CONFIG_GET_ARGS) {
|
||
|
+ gp_widget_new (GP_WIDGET_TEXT, _(menu->label), widget);
|
||
|
+ gp_widget_set_name (*widget, menu->name);
|
||
|
+
|
||
|
+ gp_widget_set_value (*widget, "0,0");
|
||
|
+ return (GP_OK);
|
||
|
+}
|
||
|
+
|
||
|
+static int
|
||
|
+_put_Canon_EOS_ZoomPosition(CONFIG_PUT_ARGS) {
|
||
|
+ uint16_t ret;
|
||
|
+ const char* val;
|
||
|
+ unsigned int x,y;
|
||
|
+ PTPParams *params = &(camera->pl->params);
|
||
|
+
|
||
|
+ if (!ptp_operation_issupported(params, PTP_OC_CANON_EOS_ZoomPosition))
|
||
|
+ return (GP_ERROR_NOT_SUPPORTED);
|
||
|
+
|
||
|
+ gp_widget_get_value(widget, &val);
|
||
|
+ if (2!=sscanf (val, "%d,%d", &x,&y)) {
|
||
|
+ gp_log (GP_LOG_DEBUG, "ptp2/canon_eos_zoomposition", "Could not parse %s (expected 'x,y')", val);
|
||
|
+ return GP_ERROR;
|
||
|
+ }
|
||
|
+ ret = ptp_canon_eos_zoomposition (params, x,y);
|
||
|
+ if (ret != PTP_RC_OK) {
|
||
|
+ gp_log (GP_LOG_DEBUG, "ptp2/canon_eos_zoomposition", "Canon zoom position %d,%d failed: 0x%x", x, y, ret);
|
||
|
+ return GP_ERROR;
|
||
|
+ }
|
||
|
+ /* Get the next set of event data */
|
||
|
+ ret = _ptp_check_eos_events (params);
|
||
|
+ if (ret != PTP_RC_OK) {
|
||
|
+ gp_log (GP_LOG_ERROR,"ptp2/canon_eos_zoomposition", "getevent failed!");
|
||
|
+ return translate_ptp_result (ret);
|
||
|
+ }
|
||
|
+ return GP_OK;
|
||
|
}
|
||
|
|
||
|
|
||
|
@@ -4241,6 +4382,8 @@
|
||
|
{ N_("Drive Canon DSLR Autofocus"), "autofocusdrive", 0, PTP_VENDOR_CANON, PTP_OC_CANON_EOS_DoAf, _get_Canon_EOS_AFDrive, _put_Canon_EOS_AFDrive },
|
||
|
{ N_("Drive Nikon DSLR Manual focus"), "manualfocusdrive", 0, PTP_VENDOR_NIKON, PTP_OC_NIKON_MfDrive, _get_Nikon_MFDrive, _put_Nikon_MFDrive },
|
||
|
{ N_("Drive Canon DSLR Manual focus"), "manualfocusdrive", 0, PTP_VENDOR_CANON, PTP_OC_CANON_EOS_DriveLens, _get_Canon_EOS_MFDrive, _put_Canon_EOS_MFDrive },
|
||
|
+ { N_("Canon EOS Zoom "), "eoszoom", 0, PTP_VENDOR_CANON, PTP_OC_CANON_EOS_Zoom, _get_Canon_EOS_Zoom, _put_Canon_EOS_Zoom},
|
||
|
+ { N_("Canon EOS Zoom Position"), "eoszoomposition", 0, PTP_VENDOR_CANON, PTP_OC_CANON_EOS_ZoomPosition, _get_Canon_EOS_ZoomPosition, _put_Canon_EOS_ZoomPosition},
|
||
|
{ 0,0,0,0,0,0,0 },
|
||
|
};
|
||
|
|
||
|
diff -ru libgphoto2-2.4.9/camlibs/ptp2/library.c libgphoto2//camlibs/ptp2/library.c
|
||
|
--- libgphoto2-2.4.9/camlibs/ptp2/library.c 2010-04-11 14:13:03.000000000 +0200
|
||
|
+++ libgphoto2//camlibs/ptp2/library.c 2010-06-17 17:05:11.958020000 +0200
|
||
|
@@ -2031,7 +2031,8 @@
|
||
|
/* delete last / or we get confused later. */
|
||
|
path->folder[ strlen(path->folder)-1 ] = '\0';
|
||
|
gp_filesystem_append (camera->fs, path->folder, path->name, context);
|
||
|
- continue; /* for RAW+JPG mode capture, we just return the last image for now. */
|
||
|
+ break;/* for RAW+JPG mode capture, we just return the first image for now, and
|
||
|
+ * let wait_for_event get the rest. */
|
||
|
}
|
||
|
if (newobject)
|
||
|
break;
|
||
|
@@ -2466,6 +2467,8 @@
|
||
|
|
||
|
init_ptp_fs (camera, context);
|
||
|
|
||
|
+ *eventtype = GP_EVENT_TIMEOUT;
|
||
|
+ *eventdata = NULL;
|
||
|
gettimeofday (&event_start,NULL);
|
||
|
if ( (params->deviceinfo.VendorExtensionID == PTP_VENDOR_CANON) &&
|
||
|
ptp_operation_issupported(params, PTP_OC_CANON_EOS_RemoteRelease)
|
||
|
@@ -2474,7 +2477,6 @@
|
||
|
|
||
|
if (!params->eos_captureenabled)
|
||
|
camera_prepare_capture (camera, context);
|
||
|
- *eventtype = GP_EVENT_TIMEOUT;
|
||
|
while (1) {
|
||
|
PTPCanon_changes_entry entry;
|
||
|
|
||
|
@@ -2589,10 +2591,8 @@
|
||
|
int isevent;
|
||
|
|
||
|
while (1) {
|
||
|
- if (_timeout_passed(&event_start, timeout)) {
|
||
|
- *eventtype = GP_EVENT_TIMEOUT;
|
||
|
+ if (_timeout_passed(&event_start, timeout))
|
||
|
break;
|
||
|
- }
|
||
|
gp_context_idle (context);
|
||
|
ret = ptp_canon_checkevent (params,&event,&isevent);
|
||
|
if (ret!=PTP_RC_OK)
|
||
|
@@ -2609,7 +2609,6 @@
|
||
|
) {
|
||
|
uint32_t newobject, hasc101;
|
||
|
|
||
|
- *eventtype = GP_EVENT_TIMEOUT;
|
||
|
while (1) {
|
||
|
int evtcnt;
|
||
|
PTPContainer *nevent = NULL;
|
||
|
diff -ru libgphoto2-2.4.9/camlibs/ptp2/usb.c libgphoto2//camlibs/ptp2/usb.c
|
||
|
--- libgphoto2-2.4.9/camlibs/ptp2/usb.c 2009-12-15 09:28:43.000000000 +0100
|
||
|
+++ libgphoto2//camlibs/ptp2/usb.c 2010-06-17 17:05:12.019025000 +0200
|
||
|
@@ -506,6 +506,7 @@
|
||
|
gp_port_get_timeout (camera->port, &timeout);
|
||
|
gp_port_set_timeout (camera->port, PTP2_FAST_TIMEOUT);
|
||
|
result = gp_port_check_int (camera->port, (char*)&usbevent, sizeof(usbevent));
|
||
|
+ if (result <= 0) result = gp_port_check_int (camera->port, (char*)&usbevent, sizeof(usbevent));
|
||
|
gp_port_set_timeout (camera->port, timeout);
|
||
|
break;
|
||
|
default:
|
||
|
diff -ru libgphoto2-2.4.9/libgphoto2/gphoto2-camera.c libgphoto2//libgphoto2/gphoto2-camera.c
|
||
|
--- libgphoto2-2.4.9/libgphoto2/gphoto2-camera.c 2010-04-11 14:30:03.000000000 +0200
|
||
|
+++ libgphoto2//libgphoto2/gphoto2-camera.c 2010-06-17 17:05:13.489925000 +0200
|
||
|
@@ -1035,8 +1035,6 @@
|
||
|
CHECK_INIT (camera, context);
|
||
|
|
||
|
if (!camera->functions->wait_for_event) {
|
||
|
- gp_context_error (context, _("This camera does "
|
||
|
- "not support event handling."));
|
||
|
CAMERA_UNUSED (camera, context);
|
||
|
return (GP_ERROR_NOT_SUPPORTED);
|
||
|
}
|