Re: [PATCH ] send-key: Implement Python API

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Jul 21, 2011 at 05:21:10PM +0800, Lai Jiangshan wrote:
> 
> Signed-off-by: Lai Jiangshan <laijs@xxxxxxxxxxxxxx>
> ---
> diff --git a/python/libvirt-override.c b/python/libvirt-override.c
> index b713b6a..1ef5bfa 100644
> --- a/python/libvirt-override.c
> +++ b/python/libvirt-override.c
> @@ -3789,6 +3789,53 @@ libvirt_virStreamSend(PyObject *self ATTRIBUTE_UNUSED,
>      return py_retval;
>  }
>  
> +static PyObject *
> +libvirt_virDomainSendKey(PyObject *self ATTRIBUTE_UNUSED,
> +                         PyObject *args)
> +{
> +    PyObject *py_retval;
> +    virDomainPtr domain;
> +    PyObject *pyobj_domain;
> +    PyObject *pyobj_list;
> +    int codeset;
> +    int holdtime;
> +    unsigned int flags;
> +    int ret;
> +    int i;
> +    unsigned int keycodes[VIR_DOMAIN_SEND_KEY_MAX_KEYS];
> +    unsigned int nkeycodes;
> +
> +    if (!PyArg_ParseTuple(args, (char *)"OiiOii:virDomainSendKey",
> +                          &pyobj_domain, &codeset, &holdtime, &pyobj_list,
> +                          &nkeycodes, &flags)) {
> +        DEBUG("%s failed to parse tuple\n", __FUNCTION__);
> +        return VIR_PY_INT_FAIL;
> +    }
> +    domain = (virDomainPtr) PyvirDomain_Get(pyobj_domain);
> +
> +    if (!PyList_Check(pyobj_list)) {
> +        return VIR_PY_INT_FAIL;
> +    }
> +
> +    if (nkeycodes != PyList_Size(pyobj_list) ||
> +        nkeycodes > VIR_DOMAIN_SEND_KEY_MAX_KEYS) {
> +        return VIR_PY_INT_FAIL;
> +    }
> +
> +    for (i = 0; i < nkeycodes; i++) {
> +        keycodes[i] = (int)PyInt_AsLong(PyList_GetItem(pyobj_list, i));
> +    }
> +
> +    LIBVIRT_BEGIN_ALLOW_THREADS;
> +    ret = virDomainSendKey(domain, codeset, holdtime, keycodes, nkeycodes, flags);
> +    LIBVIRT_END_ALLOW_THREADS;
> +
> +    DEBUG("virDomainSendKey ret=%d\n", ret);
> +
> +    py_retval = libvirt_intWrap(ret);
> +    return py_retval;
> +}
> +
>  /************************************************************************
>   *									*
>   *			The registration stuff				*
> @@ -3872,6 +3919,7 @@ static PyMethodDef libvirtMethods[] = {
>      {(char *) "virDomainGetJobInfo", libvirt_virDomainGetJobInfo, METH_VARARGS, NULL},
>      {(char *) "virDomainSnapshotListNames", libvirt_virDomainSnapshotListNames, METH_VARARGS, NULL},
>      {(char *) "virDomainRevertToSnapshot", libvirt_virDomainRevertToSnapshot, METH_VARARGS, NULL},
> +    {(char *) "virDomainSendKey", libvirt_virDomainSendKey, METH_VARARGS, NULL},
>      {NULL, NULL, 0, NULL}
>  };

ACK

Daniel
-- 
|: http://berrange.com      -o-    http://www.flickr.com/photos/dberrange/ :|
|: http://libvirt.org              -o-             http://virt-manager.org :|
|: http://autobuild.org       -o-         http://search.cpan.org/~danberr/ :|
|: http://entangle-photo.org       -o-       http://live.gnome.org/gtk-vnc :|

--
libvir-list mailing list
libvir-list@xxxxxxxxxx
https://www.redhat.com/mailman/listinfo/libvir-list


[Index of Archives]     [Virt Tools]     [Libvirt Users]     [Lib OS Info]     [Fedora Users]     [Fedora Desktop]     [Fedora SELinux]     [Big List of Linux Books]     [Yosemite News]     [KDE Users]     [Fedora Tools]