本文整理匯總了C++中GUINT32_TO_LE函數的典型用法代碼示例。如果您正苦於以下問題:C++ GUINT32_TO_LE函數的具體用法?C++ GUINT32_TO_LE怎麽用?C++ GUINT32_TO_LE使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了GUINT32_TO_LE函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: wav_open
static gint wav_open(void)
{
memcpy(&header.main_chunk, "RIFF", 4);
header.length = GUINT32_TO_LE(0);
memcpy(&header.chunk_type, "WAVE", 4);
memcpy(&header.sub_chunk, "fmt ", 4);
header.sc_len = GUINT32_TO_LE(16);
header.format = GUINT16_TO_LE(1);
header.modus = GUINT16_TO_LE(input.channels);
header.sample_fq = GUINT32_TO_LE(input.frequency);
if (input.format == FMT_U8 || input.format == FMT_S8)
header.bit_p_spl = GUINT16_TO_LE(8);
else
header.bit_p_spl = GUINT16_TO_LE(16);
header.byte_p_sec = GUINT32_TO_LE(input.frequency * header.modus * (GUINT16_FROM_LE(header.bit_p_spl) / 8));
header.byte_p_spl = GUINT16_TO_LE((GUINT16_FROM_LE(header.bit_p_spl) / (8 / input.channels)));
memcpy(&header.data_chunk, "data", 4);
header.data_length = GUINT32_TO_LE(0);
if (vfs_fwrite (& header, 1, sizeof header, output_file) != sizeof header)
return 0;
written = 0;
return 1;
}
示例2: gen_context
static gchar *
gen_context(const char *file_name,
const char *file_path)
{
struct stat st;
gsize size = 0;
MsnContextHeader header;
gchar *u8 = NULL;
guchar *base;
guchar *n;
gchar *ret;
gunichar2 *uni = NULL;
glong currentChar = 0;
glong uni_len = 0;
gsize len;
if (g_stat(file_path, &st) == 0)
size = st.st_size;
if(!file_name) {
u8 = purple_utf8_try_convert(g_basename(file_path));
file_name = u8;
}
uni = g_utf8_to_utf16(file_name, -1, NULL, &uni_len, NULL);
if(u8) {
g_free(u8);
file_name = NULL;
u8 = NULL;
}
len = sizeof(MsnContextHeader) + MAX_FILE_NAME_LEN + 4;
header.length = GUINT32_TO_LE(len);
header.unk1 = GUINT32_TO_LE(2);
header.file_size = GUINT32_TO_LE(size);
header.unk2 = GUINT32_TO_LE(0);
header.unk3 = GUINT32_TO_LE(0);
base = g_malloc(len + 1);
n = base;
memcpy(n, &header, sizeof(MsnContextHeader));
n += sizeof(MsnContextHeader);
memset(n, 0x00, MAX_FILE_NAME_LEN);
for(currentChar = 0; currentChar < uni_len; currentChar++) {
*((gunichar2 *)n + currentChar) = GUINT16_TO_LE(uni[currentChar]);
}
n += MAX_FILE_NAME_LEN;
memset(n, 0xFF, 4);
n += 4;
g_free(uni);
ret = purple_base64_encode(base, len);
g_free(base);
return ret;
}
示例3: gfire_create_im
int gfire_create_im(PurpleConnection *gc, gfire_buddy *buddy, const char *msg)
{
int length = 68+strlen(msg);
int index = 0;
gfire_data *gfire = NULL;
guint32 msgtype = 0;
guint32 imindex = 0;
guint16 slen = strlen(msg);
buddy->im++;
imindex = GUINT32_TO_LE(buddy->im);
msgtype = GUINT32_TO_LE(msgtype);
slen = GUINT16_TO_LE(slen);
gfire = (gfire_data *)gc->proto_data;
gfire_add_header(gfire->buff_out, length, 2, 2);/*add header*/
index += 5;
gfire->buff_out[index] = strlen("sid"); index++;
memcpy(gfire->buff_out + index, "sid", strlen("sid"));
index+= strlen("sid");
gfire->buff_out[index++] = 0x03;
memcpy(gfire->buff_out+index,buddy->sid, XFIRE_SID_LEN);
index += XFIRE_SID_LEN;
gfire->buff_out[index] = strlen("peermsg"); index++;
memcpy(gfire->buff_out + index, "peermsg", strlen("peermsg"));
index+= strlen("peermsg");
gfire->buff_out[index++] = 0x05;
gfire->buff_out[index++] = 0x03;
gfire->buff_out[index] = strlen("msgtype"); index++;
memcpy(gfire->buff_out + index, "msgtype", strlen("msgtype"));
index+= strlen("msgtype");
gfire->buff_out[index++] = 0x02;
memcpy(gfire->buff_out + index, &msgtype, sizeof(msgtype));
index+= sizeof(msgtype);
gfire->buff_out[index] = strlen("imindex"); index++;
memcpy(gfire->buff_out + index, "imindex", strlen("imindex"));
index+= strlen("imindex");
gfire->buff_out[index++] = 0x02;
memcpy(gfire->buff_out + index, &imindex, sizeof(imindex));
index+= sizeof(imindex);
gfire->buff_out[index] = strlen("im"); index++;
memcpy(gfire->buff_out + index, "im", strlen("im"));
index+= strlen("im");
gfire->buff_out[index++] = 0x01;
memcpy(gfire->buff_out + index, &slen, sizeof(slen));
index+= sizeof(slen);
memcpy(gfire->buff_out+index, msg, strlen(msg));
index += strlen(msg);
return index;
}
示例4: write_metadata
static void
write_metadata (GstWavEnc * wavenc)
{
GString *info_str;
GList *props;
int total = 4;
gboolean need_to_write = FALSE;
info_str = g_string_new ("LIST INFO");
for (props = wavenc->metadata->properties->properties; props;
props = props->next) {
GstPropsEntry *entry = props->data;
const char *name;
guint32 id;
name = gst_props_entry_get_name (entry);
id = get_id_from_name (name);
if (id != 0) {
const char *text;
char *tmp;
int len, req, i;
need_to_write = TRUE; /* We've got at least one entry */
gst_props_entry_get_string (entry, &text);
len = strlen (text) + 1; /* The length in the file includes the \0 */
tmp = g_strdup_printf ("%" GST_FOURCC_FORMAT "%d%s", GST_FOURCC_ARGS (id),
GUINT32_TO_LE (len), text);
g_string_append (info_str, tmp);
g_free (tmp);
/* Check that we end on an even boundary */
req = ((len + 8) + 1) & ~1;
for (i = 0; i < req - len; i++) {
g_string_append_printf (info_str, "%c", 0);
}
total += req;
}
}
if (need_to_write) {
GstBuffer *buf;
/* Now we've got all the strings together, we can write our length in */
info_str->str[4] = GUINT32_TO_LE (total);
buf = gst_buffer_new ();
gst_buffer_set_data (buf, info_str->str, info_str->len);
gst_pad_push (wavenc->srcpad, GST_DATA (buf));
g_string_free (info_str, FALSE);
}
}
示例5: fill_wave_header
static void
fill_wave_header(struct wave_header *header, int channels, int bits,
int freq, int block_size)
{
int data_size = 0x0FFFFFFF;
/* constants */
header->id_riff = GUINT32_TO_LE(0x46464952);
header->id_wave = GUINT32_TO_LE(0x45564157);
header->id_fmt = GUINT32_TO_LE(0x20746d66);
header->id_data = GUINT32_TO_LE(0x61746164);
/* wave format */
header->format = GUINT16_TO_LE(1); // PCM_FORMAT
header->channels = GUINT16_TO_LE(channels);
header->bits = GUINT16_TO_LE(bits);
header->freq = GUINT32_TO_LE(freq);
header->blocksize = GUINT16_TO_LE(block_size);
header->byterate = GUINT32_TO_LE(freq * block_size);
/* chunk sizes (fake data length) */
header->fmt_size = GUINT32_TO_LE(16);
header->data_size = GUINT32_TO_LE(data_size);
header->riff_size = GUINT32_TO_LE(4 + (8 + 16) +
(8 + data_size));
}
示例6: wav_close
static void wav_close(void)
{
if (output_file)
{
header.length = GUINT32_TO_LE(written + sizeof (struct wavhead) - 8);
header.data_length = GUINT32_TO_LE(written);
if (vfs_fseek (output_file, 0, SEEK_SET) || vfs_fwrite (& header, 1,
sizeof header, output_file) != sizeof header)
fprintf (stderr, "Error while writing to .wav output file.\n");
}
}
示例7: tnef_open
wtap_open_return_val tnef_open(wtap *wth, int *err, gchar **err_info)
{
guint32 magic;
if (!wtap_read_bytes(wth->fh, &magic, sizeof magic, err, err_info))
return (*err != WTAP_ERR_SHORT_READ) ? WTAP_OPEN_ERROR : WTAP_OPEN_NOT_MINE;
if (GUINT32_TO_LE(magic) != TNEF_SIGNATURE)
/* Not a tnef file */
return WTAP_OPEN_NOT_MINE;
/* seek back to the start of the file */
if (file_seek(wth->fh, 0, SEEK_SET, err) == -1)
return WTAP_OPEN_ERROR;
wth->file_type_subtype = WTAP_FILE_TYPE_SUBTYPE_TNEF;
wth->file_encap = WTAP_ENCAP_TNEF;
wth->snapshot_length = 0;
wth->subtype_read = tnef_read;
wth->subtype_seek_read = tnef_seek_read;
wth->file_tsprec = WTAP_TSPREC_SEC;
return WTAP_OPEN_MINE;
}
示例8: msn_slpmsg_show
void
msn_slpmsg_show(MsnMessage *msg)
{
const char *info;
gboolean text;
guint32 flags;
text = FALSE;
flags = GUINT32_TO_LE(msg->msnslp_header.flags);
switch (flags)
{
case 0x0:
info = "SLP CONTROL";
text = TRUE;
break;
case 0x2:
info = "SLP ACK"; break;
case 0x20:
case 0x1000030:
info = "SLP DATA"; break;
default:
info = "SLP UNKNOWN"; break;
}
msn_message_show_readable(msg, info, text);
}
示例9: tnef_open
int tnef_open(wtap *wth, int *err, gchar **err_info)
{
int bytes_read;
guint32 magic;
bytes_read = file_read(&magic, sizeof magic, wth->fh);
if (bytes_read != sizeof magic) {
*err = file_error(wth->fh, err_info);
return (*err != 0) ? -1 : 0;
}
if (GUINT32_TO_LE(magic) != TNEF_SIGNATURE)
/* Not a tnef file */
return 0;
/* seek back to the start of the file */
if (file_seek(wth->fh, 0, SEEK_SET, err) == -1)
return -1;
wth->file_type_subtype = WTAP_FILE_TYPE_SUBTYPE_TNEF;
wth->file_encap = WTAP_ENCAP_TNEF;
wth->snapshot_length = 0;
wth->subtype_read = tnef_read;
wth->subtype_seek_read = tnef_seek_read;
wth->tsprecision = WTAP_FILE_TSPREC_SEC;
return 1;
}
示例10: g_string_sized_new
GString *message_str(const unsigned char netmagic[4],
const char *command_,
const void *data, uint32_t data_len)
{
GString *s = g_string_sized_new(P2P_HDR_SZ + data_len);
/* network identifier (magic number) */
g_string_append_len(s, (gchar *) netmagic, 4);
/* command string */
char command[12] = {};
strncpy(command, command_, 12);
g_string_append_len(s, command, 12);
/* data length */
uint32_t data_len_le = GUINT32_TO_LE(data_len);
g_string_append_len(s, (gchar *) &data_len_le, 4);
/* data checksum */
unsigned char md32[4];
bu_Hash4(md32, data, data_len);
g_string_append_len(s, (gchar *) &md32[0], 4);
/* data payload */
if (data_len > 0)
g_string_append_len(s, data, data_len);
return s;
}
示例11: msn_dc_send_cb
static void
msn_dc_send_cb(gpointer data, gint fd, PurpleInputCondition cond)
{
MsnDirectConn *dc = data;
MsnDirectConnPacket *p;
int bytes_to_send;
int bytes_sent;
g_return_if_fail(dc != NULL);
g_return_if_fail(fd != -1);
if (g_queue_is_empty(dc->out_queue)) {
if (dc->send_handle != 0) {
purple_input_remove(dc->send_handle);
dc->send_handle = 0;
}
return;
}
p = g_queue_peek_head(dc->out_queue);
if (dc->msg_pos < 0) {
/* First we send the length of the packet */
guint32 len = GUINT32_TO_LE(p->length);
bytes_sent = send(fd, &len, 4, 0);
if (bytes_sent < 0) {
if ((errno == EAGAIN) || (errno == EWOULDBLOCK))
return;
purple_debug_warning("msn", "msn_dc_send_cb: send error\n");
msn_dc_destroy(dc);
return;
}
dc->msg_pos = 0;
}
bytes_to_send = p->length - dc->msg_pos;
bytes_sent = send(fd, p->data + dc->msg_pos, bytes_to_send, 0);
if (bytes_sent < 0) {
if ((errno == EAGAIN) || (errno == EWOULDBLOCK))
return;
purple_debug_warning("msn", "msn_dc_send_cb: send error\n");
msn_dc_destroy(dc);
return;
}
dc->progress = TRUE;
dc->msg_pos += bytes_sent;
if (dc->msg_pos == p->length) {
if (p->sent_cb != NULL)
p->sent_cb(p);
g_queue_pop_head(dc->out_queue);
msn_dc_destroy_packet(p);
dc->msg_pos = -1;
}
}
示例12: msn_directconn_parse_nonce
void
msn_directconn_parse_nonce(MsnDirectConn *directconn, const char *nonce)
{
guint32 t1;
guint16 t2;
guint16 t3;
guint16 t4;
guint64 t5;
g_return_if_fail(directconn != NULL);
g_return_if_fail(nonce != NULL);
sscanf (nonce, "%08X-%04hX-%04hX-%04hX-%012llX", &t1, &t2, &t3, &t4, &t5);
t1 = GUINT32_TO_LE(t1);
t2 = GUINT16_TO_LE(t2);
t3 = GUINT16_TO_LE(t3);
t4 = GUINT16_TO_BE(t4);
t5 = GUINT64_TO_BE(t5);
directconn->slpheader = g_new0(MsnSlpHeader, 1);
directconn->slpheader->ack_id = t1;
directconn->slpheader->ack_sub_id = t2 | (t3 << 16);
directconn->slpheader->ack_size = t4 | t5;
}
示例13: fp_print_data_get_data
/** \ingroup print_data
* Convert a stored print into a unified representation inside a data buffer.
* You can then store this data buffer in any way that suits you, and load
* it back at some later time using fp_print_data_from_data().
* \param data the stored print
* \param ret output location for the data buffer. Must be freed with free()
* after use.
* \returns the size of the freshly allocated buffer, or 0 on error.
*/
API_EXPORTED size_t fp_print_data_get_data(struct fp_print_data *data,
unsigned char **ret)
{
struct fpi_print_data_fp2 *out_data;
struct fpi_print_data_item_fp2 *out_item;
struct fp_print_data_item *item;
size_t buflen = 0;
GSList *list_item;
unsigned char *buf;
fp_dbg("");
list_item = data->prints;
while (list_item) {
item = list_item->data;
buflen += sizeof(*out_item);
buflen += item->length;
list_item = g_slist_next(list_item);
}
buflen += sizeof(*out_data);
out_data = g_malloc(buflen);
*ret = (unsigned char *) out_data;
buf = out_data->data;
out_data->prefix[0] = 'F';
out_data->prefix[1] = 'P';
out_data->prefix[2] = '2';
out_data->driver_id = GUINT16_TO_LE(data->driver_id);
out_data->devtype = GUINT32_TO_LE(data->devtype);
out_data->data_type = data->type;
list_item = data->prints;
while (list_item) {
item = list_item->data;
out_item = (struct fpi_print_data_item_fp2 *)buf;
out_item->length = GUINT32_TO_LE(item->length);
/* FIXME: fp_print_data_item->data content is not endianess agnostic */
memcpy(out_item->data, item->data, item->length);
buf += sizeof(*out_item);
buf += item->length;
list_item = g_slist_next(list_item);
}
return buflen;
}
示例14: dfu_element_to_dfuse
/**
* dfu_element_to_dfuse: (skip)
* @element: a #DfuElement
*
* Packs a DfuSe element.
*
* Returns: (transfer full): the packed data
**/
static GBytes *
dfu_element_to_dfuse (DfuElement *element)
{
DfuSeElementPrefix *el;
const guint8 *data;
gsize length;
guint8 *buf;
data = g_bytes_get_data (dfu_element_get_contents (element), &length);
buf = g_malloc0 (length + sizeof (DfuSeElementPrefix));
el = (DfuSeElementPrefix *) buf;
el->address = GUINT32_TO_LE (dfu_element_get_address (element));
el->size = GUINT32_TO_LE (length);
memcpy (buf + sizeof (DfuSeElementPrefix), data, length);
return g_bytes_new_take (buf, length + sizeof (DfuSeElementPrefix));
}
示例15: msn_directconn_write
static size_t
msn_directconn_write(MsnDirectConn *directconn,
const char *data, size_t len)
{
char *buffer, *tmp;
size_t buf_size;
size_t ret;
guint32 sent_len;
g_return_val_if_fail(directconn != NULL, 0);
buf_size = len + 4;
buffer = tmp = g_malloc(buf_size);
sent_len = GUINT32_TO_LE(len);
memcpy(tmp, &sent_len, 4);
tmp += 4;
memcpy(tmp, data, len);
tmp += len;
ret = write(directconn->fd, buffer, buf_size);
#ifdef DEBUG_DC
char *str;
str = g_strdup_printf("%s/msntest/w%.4d.bin", g_get_home_dir(), directconn->c);
FILE *tf = g_fopen(str, "w");
fwrite(buffer, 1, buf_size, tf);
fclose(tf);
g_free(str);
#endif
g_free(buffer);
#if 0
/* Let's write the length of the data. */
ret = write(directconn->fd, &len, sizeof(len));
/* Let's write the data. */
ret = write(directconn->fd, data, len);
char *str;
str = g_strdup_printf("/home/revo/msntest/w%.4d.bin", directconn->c);
FILE *tf = g_fopen(str, "w");
fwrite(&len, 1, sizeof(len), tf);
fwrite(data, 1, len, tf);
fclose(tf);
g_free(str);
#endif
directconn->c++;
return ret;
}