本文整理汇总了C++中P_UNLIKELY函数的典型用法代码示例。如果您正苦于以下问题:C++ P_UNLIKELY函数的具体用法?C++ P_UNLIKELY怎么用?C++ P_UNLIKELY使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了P_UNLIKELY函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: p_hash_table_insert
P_LIB_API void
p_hash_table_insert (PHashTable *table, ppointer key, ppointer value)
{
PHashTableNode *node;
puint hash;
if (P_UNLIKELY (table == NULL))
return;
if ((node = pp_hash_table_find_node (table, key)) == NULL) {
if (P_UNLIKELY ((node = p_malloc0 (sizeof (PHashTableNode))) == NULL)) {
P_ERROR ("PHashTable::p_hash_table_insert: failed to allocate memory");
return;
}
hash = pp_hash_table_calc_hash (key, table->size);
/* Insert a new node in front of others */
node->key = key;
node->value = value;
node->next = table->table[hash];
table->table[hash] = node;
} else
node->value = value;
}
示例2: p_strtok
P_LIB_API pchar *
p_strtok (pchar *str, const pchar *delim, pchar **buf)
{
if (P_UNLIKELY (delim == NULL))
return str;
#ifdef P_OS_WIN
# ifdef P_CC_MSVC
if (P_UNLIKELY (buf == NULL))
return str;
# if _MSC_VER < 1400
P_UNUSED (buf);
return strtok (str, delim);
# else
return strtok_s (str, delim, buf);
# endif
# else
P_UNUSED (buf);
return strtok (str, delim);
# endif
#else
if (P_UNLIKELY (buf == NULL))
return str;
return strtok_r (str, delim, buf);
#endif
}
示例3: p_shm_buffer_clear
P_LIB_API void
p_shm_buffer_clear (PShmBuffer *buf)
{
ppointer addr;
psize size;
if (P_UNLIKELY (buf == NULL))
return;
if (P_UNLIKELY ((addr = p_shm_get_address (buf->shm)) == NULL)) {
P_ERROR ("PShmBuffer::p_shm_buffer_clear: p_shm_get_address() failed");
return;
}
size = p_shm_get_size (buf->shm);
if (P_UNLIKELY (p_shm_lock (buf->shm, NULL) == FALSE)) {
P_ERROR ("PShmBuffer::p_shm_buffer_clear: p_shm_lock() failed");
return;
}
memset (addr, 0, size);
if (P_UNLIKELY (p_shm_unlock (buf->shm, NULL) == FALSE))
P_ERROR ("PShmBuffer::p_shm_buffer_clear: p_shm_unlock() failed");
}
示例4: p_dir_create
P_LIB_API pboolean
p_dir_create (const pchar *path,
pint mode,
PError **error)
{
P_UNUSED (mode);
if (P_UNLIKELY (path == NULL)) {
p_error_set_error_p (error,
(pint) P_ERROR_IO_INVALID_ARGUMENT,
0,
"Invalid input argument");
return FALSE;
}
if (p_dir_is_exists (path))
return TRUE;
if (P_UNLIKELY (CreateDirectoryA (path, NULL) == 0)) {
p_error_set_error_p (error,
(pint) p_error_get_last_io (),
p_error_get_last_system (),
"Failed to call CreateDirectoryA() to create directory");
return FALSE;
} else
return TRUE;
}
示例5: p_dir_remove
P_LIB_API pboolean
p_dir_remove (const pchar *path,
PError **error)
{
if (P_UNLIKELY (path == NULL)) {
p_error_set_error_p (error,
(pint) P_ERROR_IO_INVALID_ARGUMENT,
0,
"Invalid input argument");
return FALSE;
}
if (!p_dir_is_exists (path)) {
p_error_set_error_p (error,
(pint) P_ERROR_IO_NOT_EXISTS,
0,
"Specified directory doesn't exist");
return FALSE;
}
if (P_UNLIKELY (RemoveDirectoryA (path) == 0)) {
p_error_set_error_p (error,
(pint) p_error_get_last_io (),
p_error_get_last_system (),
"Failed to call RemoveDirectoryA() to remove directory");
return FALSE;
} else
return TRUE;
}
示例6: p_dir_get_next_entry
P_LIB_API PDirEntry *
p_dir_get_next_entry (PDir *dir,
PError **error)
{
PDirEntry *ret;
DWORD dwAttrs;
if (P_UNLIKELY (dir == NULL)) {
p_error_set_error_p (error,
(pint) P_ERROR_IO_INVALID_ARGUMENT,
0,
"Invalid input argument");
return NULL;
}
if (dir->cached == TRUE)
dir->cached = FALSE;
else {
if (P_UNLIKELY (dir->search_handle == INVALID_HANDLE_VALUE)) {
p_error_set_error_p (error,
(pint) P_ERROR_IO_INVALID_ARGUMENT,
0,
"Not a valid (or closed) directory stream");
return NULL;
}
if (P_UNLIKELY (!FindNextFileA (dir->search_handle, &dir->find_data))) {
p_error_set_error_p (error,
(pint) p_error_get_last_io (),
p_error_get_last_system (),
"Failed to call FindNextFileA() to read directory stream");
FindClose (dir->search_handle);
dir->search_handle = INVALID_HANDLE_VALUE;
return NULL;
}
}
if (P_UNLIKELY ((ret = p_malloc0 (sizeof (PDirEntry))) == NULL)) {
p_error_set_error_p (error,
(pint) P_ERROR_IO_NO_RESOURCES,
0,
"Failed to allocate memory for directory entry");
return NULL;
}
ret->name = p_strdup (dir->find_data.cFileName);
dwAttrs = dir->find_data.dwFileAttributes;
if (dwAttrs & FILE_ATTRIBUTE_DIRECTORY)
ret->type = P_DIR_ENTRY_TYPE_DIR;
else if (dwAttrs & FILE_ATTRIBUTE_DEVICE)
ret->type = P_DIR_ENTRY_TYPE_OTHER;
else
ret->type = P_DIR_ENTRY_TYPE_FILE;
return ret;
}
示例7: p_dir_new
P_LIB_API PDir *
p_dir_new (const pchar *path,
PError **error)
{
PDir *ret;
pchar *pathp;
if (P_UNLIKELY (path == NULL)) {
p_error_set_error_p (error,
(pint) P_ERROR_IO_INVALID_ARGUMENT,
0,
"Invalid input argument");
return NULL;
}
if (P_UNLIKELY ((ret = p_malloc0 (sizeof (PDir))) == NULL)) {
p_error_set_error_p (error,
(pint) P_ERROR_IO_NO_RESOURCES,
0,
"Failed to allocate memory for directory structure");
return NULL;
}
if (P_UNLIKELY (!GetFullPathNameA (path, MAX_PATH, ret->path, NULL))) {
p_error_set_error_p (error,
(pint) p_error_get_last_io (),
p_error_get_last_system (),
"Failed to call GetFullPathNameA() to get directory path");
p_free (ret);
return NULL;
}
/* Append the search pattern "\\*\0" to the directory name */
pathp = strchr (ret->path, '\0');
if (ret->path < pathp && *(pathp - 1) != '\\' && *(pathp - 1) != ':')
*pathp++ = '\\';
*pathp++ = '*';
*pathp = '\0';
/* Open directory stream and retrieve the first entry */
ret->search_handle = FindFirstFileA (ret->path, &ret->find_data);
if (P_UNLIKELY (ret->search_handle == INVALID_HANDLE_VALUE)) {
p_error_set_error_p (error,
(pint) p_error_get_last_io (),
p_error_get_last_system (),
"Failed to call FindFirstFileA() to open directory stream");
p_free (ret);
return NULL;
}
ret->cached = TRUE;
ret->orig_path = p_strdup (path);
return ret;
}
示例8: p_shm_buffer_read
P_LIB_API pint
p_shm_buffer_read (PShmBuffer *buf,
ppointer storage,
psize len,
PError **error)
{
psize read_pos, write_pos;
psize data_aval, to_copy;
puint i;
ppointer addr;
if (P_UNLIKELY (buf == NULL || storage == NULL || len == 0)) {
p_error_set_error_p (error,
(pint) P_ERROR_IPC_INVALID_ARGUMENT,
0,
"Invalid input argument");
return -1;
}
if (P_UNLIKELY ((addr = p_shm_get_address (buf->shm)) == NULL)) {
p_error_set_error_p (error,
(pint) P_ERROR_IPC_INVALID_ARGUMENT,
0,
"Unable to get shared memory address");
return -1;
}
if (P_UNLIKELY (p_shm_lock (buf->shm, error) == FALSE))
return -1;
memcpy (&read_pos, (pchar *) addr + P_SHM_BUFFER_READ_OFFSET, sizeof (read_pos));
memcpy (&write_pos, (pchar *) addr + P_SHM_BUFFER_WRITE_OFFSET, sizeof (write_pos));
if (read_pos == write_pos) {
if (P_UNLIKELY (p_shm_unlock (buf->shm, error) == FALSE))
return -1;
return 0;
}
data_aval = pp_shm_buffer_get_used_space (buf);
to_copy = (data_aval <= len) ? data_aval : len;
for (i = 0; i < to_copy; ++i)
memcpy ((pchar *) storage + i,
(pchar *) addr + P_SHM_BUFFER_DATA_OFFSET + ((read_pos + i) % buf->size),
1);
read_pos = (read_pos + to_copy) % buf->size;
memcpy ((pchar *) addr + P_SHM_BUFFER_READ_OFFSET, &read_pos, sizeof (read_pos));
if (P_UNLIKELY (p_shm_unlock (buf->shm, error) == FALSE))
return -1;
return (pint) to_copy;
}
示例9: p_mutex_free
P_LIB_API void
p_mutex_free (PMutex *mutex)
{
if (P_UNLIKELY (mutex == NULL))
return;
if (P_UNLIKELY (mutex_destroy (&mutex->hdl) != 0))
P_ERROR ("PMutex::p_mutex_unlock: mutex_destroy() failed");
p_free (mutex);
}
示例10: p_rwlock_free
P_LIB_API void
p_rwlock_free (PRWLock *lock)
{
if (P_UNLIKELY (lock == NULL))
return;
if (P_UNLIKELY (rwlock_destroy (&lock->hdl) != 0))
P_ERROR ("PRWLock::p_rwlock_free: rwlock_destroy() failed");
p_free (lock);
}
示例11: p_shm_new
P_LIB_API PShm *
p_shm_new (const pchar *name,
psize size,
PShmAccessPerms perms,
PError **error)
{
PShm *ret;
pchar *new_name;
if (P_UNLIKELY (name == NULL)) {
p_error_set_error_p (error,
(pint) P_ERROR_IPC_INVALID_ARGUMENT,
0,
"Invalid input argument");
return NULL;
}
if (P_UNLIKELY ((ret = p_malloc0 (sizeof (PShm))) == NULL)) {
p_error_set_error_p (error,
(pint) P_ERROR_IPC_NO_RESOURCES,
0,
"Failed to allocate memory for shared segment");
return NULL;
}
if (P_UNLIKELY ((new_name = p_malloc0 (strlen (name) + strlen (P_SHM_SUFFIX) + 1)) == NULL)) {
p_error_set_error_p (error,
(pint) P_ERROR_IPC_NO_RESOURCES,
0,
"Failed to allocate memory for segment name");
p_shm_free (ret);
return NULL;
}
strcpy (new_name, name);
strcat (new_name, P_SHM_SUFFIX);
ret->platform_key = p_ipc_get_platform_key (new_name, FALSE);
ret->perms = perms;
ret->size = size;
p_free (new_name);
if (P_UNLIKELY (pp_shm_create_handle (ret, error) == FALSE)) {
p_shm_free (ret);
return NULL;
}
if (P_LIKELY (ret->size > size && size != 0))
ret->size = size;
return ret;
}
示例12: p_shm_buffer_write
P_LIB_API pssize
p_shm_buffer_write (PShmBuffer *buf,
ppointer data,
psize len,
PError **error)
{
psize read_pos, write_pos;
puint i;
ppointer addr;
if (P_UNLIKELY (buf == NULL || data == NULL || len == 0)) {
p_error_set_error_p (error,
(pint) P_ERROR_IPC_INVALID_ARGUMENT,
0,
"Invalid input argument");
return -1;
}
if (P_UNLIKELY ((addr = p_shm_get_address (buf->shm)) == NULL)) {
p_error_set_error_p (error,
(pint) P_ERROR_IPC_INVALID_ARGUMENT,
0,
"Unable to get shared memory address");
return -1;
}
if (P_UNLIKELY (p_shm_lock (buf->shm, error) == FALSE))
return -1;
memcpy (&read_pos, (pchar *) addr + P_SHM_BUFFER_READ_OFFSET, sizeof (read_pos));
memcpy (&write_pos, (pchar *) addr + P_SHM_BUFFER_WRITE_OFFSET, sizeof (write_pos));
if (pp_shm_buffer_get_free_space (buf) < len) {
if (P_UNLIKELY (p_shm_unlock (buf->shm, error) == FALSE))
return -1;
return 0;
}
for (i = 0; i < len; ++i)
memcpy ((pchar *) addr + P_SHM_BUFFER_DATA_OFFSET + ((write_pos + i) % buf->size),
(pchar *) data + i,
1);
write_pos = (write_pos + len) % buf->size;
memcpy ((pchar *) addr + P_SHM_BUFFER_WRITE_OFFSET, &write_pos, sizeof (write_pos));
if (P_UNLIKELY (p_shm_unlock (buf->shm, error) == FALSE))
return -1;
return (pssize) len;
}
示例13: p_rwlock_writer_lock
P_LIB_API pboolean
p_rwlock_writer_lock (PRWLock *lock)
{
if (P_UNLIKELY (lock == NULL))
return FALSE;
if (P_UNLIKELY (rw_wrlock (&lock->hdl) == 0))
return TRUE;
else {
P_ERROR ("PRWLock::p_rwlock_writer_lock: rw_wrlock() failed");
return FALSE;
}
}
示例14: p_dir_free
P_LIB_API void
p_dir_free (PDir *dir)
{
if (P_UNLIKELY (dir == NULL))
return;
if (P_LIKELY (dir->dir != NULL)) {
if (P_UNLIKELY (closedir (dir->dir) != 0))
P_ERROR ("PDir::p_dir_free: closedir() failed");
}
p_free (dir->path);
p_free (dir->orig_path);
p_free (dir);
}
示例15: p_error_copy
P_LIB_API PError *
p_error_copy (PError *error)
{
PError *ret;
if (P_UNLIKELY (error == NULL))
return NULL;
if (P_UNLIKELY ((ret = p_error_new_literal (error->code,
error->native_code,
error->message)) == NULL))
return NULL;
return ret;
}