本文整理汇总了C++中caml_acquire_runtime_system函数的典型用法代码示例。如果您正苦于以下问题:C++ caml_acquire_runtime_system函数的具体用法?C++ caml_acquire_runtime_system怎么用?C++ caml_acquire_runtime_system使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了caml_acquire_runtime_system函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: ocaml_gstreamer_buffer_of_data
CAMLprim value ocaml_gstreamer_buffer_of_data(value _ba, value _off, value _len)
{
CAMLparam1(_ba);
int bufoff = Int_val(_off);
int buflen = Int_val(_len);
GstBuffer *gstbuf;
GstMapInfo map;
gboolean bret;
assert(buflen+bufoff <= Caml_ba_array_val(_ba)->dim[0]);
caml_release_runtime_system();
gstbuf = gst_buffer_new_and_alloc(buflen);
bret = gst_buffer_map(gstbuf, &map, GST_MAP_WRITE);
caml_acquire_runtime_system();
if(!bret) caml_raise_constant(*caml_named_value("gstreamer_exn_failure"));
memcpy(map.data, (unsigned char*)Caml_ba_data_val(_ba)+bufoff, buflen);
caml_release_runtime_system();
gst_buffer_unmap(gstbuf, &map);
caml_acquire_runtime_system();
CAMLreturn(value_of_buffer(gstbuf));
}
示例2: ocaml_gstreamer_appsrc_push_buffer_data
CAMLprim value ocaml_gstreamer_appsrc_push_buffer_data(value _as, value _buf)
{
CAMLparam2(_as, _buf);
int buflen = Caml_ba_array_val(_buf)->dim[0];
appsrc *as = Appsrc_val(_as);
GstBuffer *gstbuf;
GstMapInfo map;
GstFlowReturn ret;
gboolean bret;
caml_release_runtime_system();
gstbuf = gst_buffer_new_and_alloc(buflen);
bret = gst_buffer_map(gstbuf, &map, GST_MAP_WRITE);
caml_acquire_runtime_system();
if(!bret) caml_raise_constant(*caml_named_value("gstreamer_exn_failure"));
memcpy(map.data, (unsigned char*)Caml_ba_data_val(_buf), buflen);
caml_release_runtime_system();
gst_buffer_unmap(gstbuf, &map);
ret = gst_app_src_push_buffer(as->appsrc, gstbuf);
caml_acquire_runtime_system();
if (ret != GST_FLOW_OK) caml_raise_constant(*caml_named_value("gstreamer_exn_failure"));
CAMLreturn(Val_unit);
}
示例3: ocaml_gstreamer_appsink_pull_buffer
CAMLprim value ocaml_gstreamer_appsink_pull_buffer(value _as, value string_mode)
{
CAMLparam1(_as);
CAMLlocal1(ans);
appsink *as = Appsink_val(_as);
GstSample *gstsample;
GstBuffer *gstbuf;
GstMapInfo map;
intnat len;
gboolean ret;
caml_release_runtime_system();
gstsample = gst_app_sink_pull_sample(as->appsink);
caml_acquire_runtime_system();
if (!gstsample)
{
if (gst_app_sink_is_eos(as->appsink))
caml_raise_constant(*caml_named_value("gstreamer_exn_eos"));
else
caml_raise_constant(*caml_named_value("gstreamer_exn_failure"));
}
caml_release_runtime_system();
gstbuf = gst_sample_get_buffer(gstsample);
caml_acquire_runtime_system();
if (!gstbuf) caml_raise_constant(*caml_named_value("gstreamer_exn_failure"));
caml_release_runtime_system();
ret = gst_buffer_map(gstbuf, &map, GST_MAP_READ);
caml_acquire_runtime_system();
if (!ret) caml_raise_constant(*caml_named_value("gstreamer_exn_failure"));
len = map.size;
if (string_mode == Val_false) {
ans = caml_ba_alloc(CAML_BA_C_LAYOUT | CAML_BA_UINT8, 1, NULL, &len);
memcpy(Caml_ba_data_val(ans), map.data, len);
} else {
ans = caml_alloc_string(len);
memcpy(String_val(ans), map.data, len);
}
caml_release_runtime_system();
gst_buffer_unmap(gstbuf, &map);
gst_sample_unref(gstsample);
caml_acquire_runtime_system();
CAMLreturn(ans);
}
示例4: stub_sem_wait
CAMLprim value stub_sem_wait(value sem) {
CAMLparam1(sem);
CAMLlocal2(result, perrno);
int rc, lerrno;
sem_t *s;
s = *Sem_val(sem);
if (NULL == s) {
lerrno = EINVAL;
goto ERROR;
}
caml_release_runtime_system();
rc = sem_wait(s);
lerrno = errno;
caml_acquire_runtime_system();
if (0 != rc) {
goto ERROR;
}
result = caml_alloc(1, 0); // Result.Ok
Store_field(result, 0, Val_unit);
goto END;
ERROR:
perrno = caml_alloc(2, 0);
Store_field(perrno, 0, eunix); // `EUnix
Store_field(perrno, 1, unix_error_of_code(lerrno));
result = caml_alloc(1, 1); // Result.Error
Store_field(result, 0, perrno);
END:
CAMLreturn(result);
}
示例5: stub_sha1_update_fd
CAMLprim value stub_sha1_update_fd(value ctx, value fd, value len)
{
CAMLparam3(ctx, fd, len);
unsigned char buf[BLKSIZE];
struct sha1_ctx ctx_dup = *GET_CTX_STRUCT(ctx);
intnat ret, rest = Long_val(len);
caml_release_runtime_system();
do {
ret = rest < sizeof(buf) ? rest : sizeof(buf);
ret = read(Long_val(fd), buf, ret);
if (ret <= 0) break;
rest -= ret;
sha1_update(&ctx_dup, buf, ret);
} while (ret > 0 && rest > 0);
caml_acquire_runtime_system();
if (ret < 0)
caml_failwith("read error");
*GET_CTX_STRUCT(ctx) = ctx_dup;
CAMLreturn(Val_long(Long_val(len) - rest));
}
示例6: unix_unistd_access
int unix_unistd_access(const char *pathname, int mode) {
int retval;
caml_release_runtime_system();
retval = access(pathname, mode);
caml_acquire_runtime_system();
return retval;
}
示例7: unix_unistd_read
ssize_t unix_unistd_read(int fd, void *buf, size_t count) {
ssize_t retval;
caml_release_runtime_system();
retval = read(fd, buf, count);
caml_acquire_runtime_system();
return retval;
}
示例8: unix_unistd_fchown
int unix_unistd_fchown(int fd, uid_t owner, gid_t group) {
int retval;
caml_release_runtime_system();
retval = fchown(fd, owner, group);
caml_acquire_runtime_system();
return retval;
}
示例9: unix_unistd_ftruncate
int unix_unistd_ftruncate(int fd, off_t length) {
int retval;
caml_release_runtime_system();
retval = ftruncate(fd, length);
caml_acquire_runtime_system();
return retval;
}
示例10: unix_unistd_symlink
int unix_unistd_symlink(const char *target, const char *linkpath) {
int retval;
caml_release_runtime_system();
retval = symlink(target, linkpath);
caml_acquire_runtime_system();
return retval;
}
示例11: ocaml_gstreamer_bus_pop_filtered
CAMLprim value ocaml_gstreamer_bus_pop_filtered(value _bus, value _filter)
{
CAMLparam2(_bus, _filter);
CAMLlocal1(ans);
GstBus *bus = Bus_val(_bus);
GstMessageType filter = 0;
GstMessage *msg;
int i;
for(i = 0; i < Wosize_val(_filter); i++)
filter |= message_type_of_int(Int_val(Field(_filter, i)));
caml_release_runtime_system();
msg = gst_bus_pop_filtered(bus, filter);
caml_acquire_runtime_system();
if(!msg)
ans = Val_int(0);
else
{
ans = caml_alloc_tuple(1);
Store_field(ans, 0, value_of_message(msg));
}
CAMLreturn(ans);
}
示例12: ocaml_gstreamer_init
CAMLprim value ocaml_gstreamer_init(value _argv)
{
CAMLparam1(_argv);
char **argv = NULL;
int argc = 0;
int len, i;
if (Is_block(_argv))
{
_argv = Field(_argv, 0);
argc = Wosize_val(_argv);
argv = malloc(argc*sizeof(char*));
for(i = 0; i < argc; i++)
{
len = caml_string_length(Field(_argv,i));
argv[i] = malloc(len+1);
memcpy(argv[i], String_val(Field(_argv,i)), len+1);
}
}
caml_release_runtime_system();
gst_init(&argc, &argv);
for(i = 0; i < argc; i++)
free(argv[i]);
free(argv);
caml_acquire_runtime_system();
CAMLreturn(Val_unit);
}
示例13: unix_fcntl_open_none
int unix_fcntl_open_none(const char *path, int oflag) {
int retval;
caml_release_runtime_system();
retval = open(path, oflag);
caml_acquire_runtime_system();
return retval;
}
示例14: unix_fcntl_open_perms
int unix_fcntl_open_perms(const char *path, int oflag, mode_t perms) {
int retval;
caml_release_runtime_system();
retval = open(path, oflag, perms);
caml_acquire_runtime_system();
return retval;
}
示例15: stub_launch_activate_socket
CAMLprim value stub_launch_activate_socket(value name) {
CAMLparam1(name);
CAMLlocal1(result);
const char *c_name = caml_strdup(String_val(name));
int *listening_fds = NULL;
size_t n_listening_fds = 0;
int err;
caml_release_runtime_system();
err = launch_activate_socket(c_name, &listening_fds, &n_listening_fds);
caml_acquire_runtime_system();
caml_stat_free((void*)c_name);
switch (err) {
case 0:
result = caml_alloc_tuple(n_listening_fds);
for (int i = 0; i < n_listening_fds; i++) {
Store_field(result, i, Val_int(*(listening_fds + i)));
}
break;
default:
unix_error(err, "launch_activate_socket", name);
break;
}
CAMLreturn(result);
}