mirror of
https://github.com/irungentoo/toxcore.git
synced 2024-03-22 13:30:51 +08:00
commit
4cc4e79088
|
@ -169,7 +169,7 @@ START_TEST(test_getself_name)
|
||||||
char nick_check[len];
|
char nick_check[len];
|
||||||
|
|
||||||
setname(m, (uint8_t *)nickname, len);
|
setname(m, (uint8_t *)nickname, len);
|
||||||
getself_name(m, (uint8_t *)nick_check);
|
getself_name(m, (uint8_t *)nick_check, len);
|
||||||
|
|
||||||
ck_assert_msg((!STRINGS_EQUAL(nickname, nick_check)),
|
ck_assert_msg((!STRINGS_EQUAL(nickname, nick_check)),
|
||||||
"getself_name failed to return the known name!\n"
|
"getself_name failed to return the known name!\n"
|
||||||
|
|
|
@ -267,10 +267,18 @@ int setname(Messenger *m, uint8_t * name, uint16_t length)
|
||||||
put it in name
|
put it in name
|
||||||
name needs to be a valid memory location with a size of at least MAX_NAME_LENGTH bytes.
|
name needs to be a valid memory location with a size of at least MAX_NAME_LENGTH bytes.
|
||||||
return the length of the name */
|
return the length of the name */
|
||||||
uint16_t getself_name(Messenger *m, uint8_t *name)
|
uint16_t getself_name(Messenger *m, uint8_t *name, uint16_t nlen)
|
||||||
{
|
{
|
||||||
|
uint16_t len;
|
||||||
|
|
||||||
|
if (name == NULL || nlen == 0) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
len = MIN(nlen, m->name_length);
|
||||||
memcpy(name, m->name, m->name_length);
|
memcpy(name, m->name, m->name_length);
|
||||||
return m->name_length;
|
|
||||||
|
return len;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get name of friendnumber
|
/* get name of friendnumber
|
||||||
|
|
|
@ -196,10 +196,18 @@ int m_sendaction(Messenger *m, int friendnumber, uint8_t *action, uint32_t lengt
|
||||||
return -1 if failure */
|
return -1 if failure */
|
||||||
int setname(Messenger *m, uint8_t *name, uint16_t length);
|
int setname(Messenger *m, uint8_t *name, uint16_t length);
|
||||||
|
|
||||||
/* get our nickname
|
/**
|
||||||
put it in name
|
* @brief Get your nickname.
|
||||||
return the length of the name*/
|
*
|
||||||
uint16_t getself_name(Messenger *m, uint8_t *name);
|
* @param[in] m The messanger context to use.
|
||||||
|
*
|
||||||
|
* @param[inout] name Pointer to a string for the name.
|
||||||
|
*
|
||||||
|
* @param[in] nlen The length of the string buffer.
|
||||||
|
*
|
||||||
|
* @return Return the length of the name, 0 on error.
|
||||||
|
*/
|
||||||
|
uint16_t getself_name(Messenger *m, uint8_t *name, uint16_t nlen);
|
||||||
|
|
||||||
/* get name of friendnumber
|
/* get name of friendnumber
|
||||||
put it in name
|
put it in name
|
||||||
|
|
|
@ -113,7 +113,7 @@ char *format_message(Messenger *m, char *message, int friendnum)
|
||||||
if (friendnum != -1) {
|
if (friendnum != -1) {
|
||||||
getname(m, friendnum, (uint8_t*)name);
|
getname(m, friendnum, (uint8_t*)name);
|
||||||
} else {
|
} else {
|
||||||
getself_name(m, (uint8_t*)name);
|
getself_name(m, (uint8_t*)name, sizeof(name));
|
||||||
}
|
}
|
||||||
char *msg = malloc(100+strlen(message)+strlen(name)+1);
|
char *msg = malloc(100+strlen(message)+strlen(name)+1);
|
||||||
|
|
||||||
|
|
|
@ -210,7 +210,7 @@ void execute(ToxWindow *self, ChatContext *ctx, Messenger *m, char *cmd, struct
|
||||||
wattroff(ctx->history, COLOR_PAIR(2));
|
wattroff(ctx->history, COLOR_PAIR(2));
|
||||||
|
|
||||||
uint8_t selfname[MAX_NAME_LENGTH];
|
uint8_t selfname[MAX_NAME_LENGTH];
|
||||||
int len = getself_name(m, selfname);
|
int len = getself_name(m, selfname, sizeof(selfname));
|
||||||
char msg[MAX_STR_SIZE-len-4];
|
char msg[MAX_STR_SIZE-len-4];
|
||||||
snprintf(msg, sizeof(msg), "* %s %s\n", (uint8_t*) selfname, action);
|
snprintf(msg, sizeof(msg), "* %s %s\n", (uint8_t*) selfname, action);
|
||||||
|
|
||||||
|
|
|
@ -28,65 +28,83 @@
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
#include <shlobj.h>
|
#include <shlobj.h>
|
||||||
#include <direct.h>
|
#include <direct.h>
|
||||||
#endif
|
#else /* WIN32 */
|
||||||
|
|
||||||
#ifdef __APPLE__
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <pwd.h>
|
#include <pwd.h>
|
||||||
#endif
|
#endif /* WIN32 */
|
||||||
|
|
||||||
#include "configdir.h"
|
#include "configdir.h"
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* Retrieves a correct configuration directory, depending on the OS used, with a trailing slash
|
* @brief Get the users config directory.
|
||||||
|
*
|
||||||
|
* This is without a trailing slash.
|
||||||
|
*
|
||||||
|
* @return The users config dir or NULL on error.
|
||||||
*/
|
*/
|
||||||
char *get_user_config_dir(void)
|
char *get_user_config_dir(void)
|
||||||
{
|
{
|
||||||
char *user_config_dir;
|
char *user_config_dir;
|
||||||
|
#ifdef WIN32
|
||||||
|
char appdata[MAX_PATH];
|
||||||
|
BOOL ok;
|
||||||
|
|
||||||
#ifdef WIN32
|
ok = SHGetSpecialFolderPathA(NULL, appdata, CSIDL_PROFILE, TRUE);
|
||||||
|
if (!ok) {
|
||||||
char appdata[MAX_PATH];
|
return NULL;
|
||||||
HRESULT result = SHGetFolderPath(
|
|
||||||
NULL,
|
|
||||||
CSIDL_APPDATA,
|
|
||||||
NULL,
|
|
||||||
SHGFP_TYPE_CURRENT,
|
|
||||||
appdata
|
|
||||||
)
|
|
||||||
if (!result) return NULL;
|
|
||||||
|
|
||||||
user_config_dir = strdup(appdata);
|
|
||||||
|
|
||||||
return user_config_dir;
|
|
||||||
|
|
||||||
#elif defined __APPLE__
|
|
||||||
|
|
||||||
struct passwd *pass = getpwuid(getuid());
|
|
||||||
if (!pass) return NULL;
|
|
||||||
char *home = pass->pw_dir;
|
|
||||||
user_config_dir = malloc(strlen(home) + strlen("/Library/Application Support") + 1);
|
|
||||||
|
|
||||||
if(user_config_dir) {
|
|
||||||
strcpy(user_config_dir, home);
|
|
||||||
strcat(user_config_dir, "/Library/Application Support");
|
|
||||||
}
|
|
||||||
return user_config_dir;
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
if (getenv("XDG_CONFIG_HOME")) {
|
|
||||||
user_config_dir = strdup(getenv("XDG_CONFIG_HOME"));
|
|
||||||
} else {
|
|
||||||
user_config_dir = malloc(strlen(getenv("HOME")) + strlen("/.config") + 1);
|
|
||||||
if (user_config_dir) {
|
|
||||||
strcpy(user_config_dir, getenv("HOME"));
|
|
||||||
strcat(user_config_dir, "/.config");
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
return user_config_dir;
|
|
||||||
|
|
||||||
#endif
|
user_config_dir = strdup(appdata);
|
||||||
|
|
||||||
|
return user_config_dir;
|
||||||
|
|
||||||
|
#else /* WIN32 */
|
||||||
|
|
||||||
|
#ifndef NSS_BUFLEN_PASSWD
|
||||||
|
#define NSS_BUFLEN_PASSWD 4096
|
||||||
|
#endif /* NSS_BUFLEN_PASSWD */
|
||||||
|
|
||||||
|
struct passwd pwd;
|
||||||
|
struct passwd *pwdbuf;
|
||||||
|
const char *home;
|
||||||
|
char buf[NSS_BUFLEN_PASSWD];
|
||||||
|
size_t len;
|
||||||
|
int rc;
|
||||||
|
|
||||||
|
rc = getpwuid_r(getuid(), &pwd, buf, NSS_BUFLEN_PASSWD, &pwdbuf);
|
||||||
|
if (rc == 0) {
|
||||||
|
home = pwd.pw_dir;
|
||||||
|
} else {
|
||||||
|
home = getenv("HOME");
|
||||||
|
if (home == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
/* env variables can be tainted */
|
||||||
|
snprintf(buf, sizeof(buf), "%s", home);
|
||||||
|
home = buf;
|
||||||
|
}
|
||||||
|
|
||||||
|
# if defined(__APPLE__)
|
||||||
|
len = strlen(home) + strlen("/Library/Application Support") + 1;
|
||||||
|
user_config_dir = malloc(len);
|
||||||
|
if (user_config_dir == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
snprintf(user_config_dir, len, "%s/Library/Application Support", home);
|
||||||
|
# else /* __APPLE__ */
|
||||||
|
len = strlen(home) + strlen("/.config") + 1;
|
||||||
|
user_config_dir = malloc(len);
|
||||||
|
if (user_config_dir == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
snprintf(user_config_dir, len, "%s/.config", home);
|
||||||
|
# endif /* __APPLE__ */
|
||||||
|
|
||||||
|
return user_config_dir;
|
||||||
|
#undef NSS_BUFLEN_PASSWD
|
||||||
|
#endif /* WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
Loading…
Reference in New Issue
Block a user