mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
Rename 'ret' variables passed from allocation to return.
I mentioned recently (in commit 9e7d4c53d8
) message that I'm no
longer fond of the variable name 'ret', because it's used in two quite
different contexts: it's the return value from a subroutine you just
called (e.g. 'int ret = read(fd, buf, len);' and then check for error
or EOF), or it's the value you're preparing to return from the
_containing_ routine (maybe by assigning it a default value and then
conditionally modifying it, or by starting at NULL and reallocating,
or setting it just before using the 'goto out' cleanup idiom). In the
past I've occasionally made mistakes by forgetting which meaning the
variable had, or accidentally conflating both uses.
If all else fails, I now prefer 'retd' (short for 'returned') in the
former situation, and 'toret' (obviously, the value 'to return') in
the latter case. But even better is to pick a name that actually says
something more specific about what the thing actually is.
One particular bad habit throughout this codebase is to have a set of
functions that deal with some object type (say 'Foo'), all *but one*
of which take a 'Foo *foo' parameter, but the foo_new() function
starts with 'Foo *ret = snew(Foo)'. If all the rest of them think the
canonical name for the ambient Foo is 'foo', so should foo_new()!
So here's a no-brainer start on cutting down on the uses of 'ret': I
looked for all the cases where it was being assigned the result of an
allocation, and renamed the variable to be a description of the thing
being allocated. In the case of a new() function belonging to a
family, I picked the same name as the rest of the functions in its own
family, for consistency. In other cases I picked something sensible.
One case where it _does_ make sense not to use your usual name for the
variable type is when you're cloning an existing object. In that case,
_neither_ of the Foo objects involved should be called 'foo', because
it's ambiguous! They should be named so you can see which is which. In
the two cases I found here, I've called them 'orig' and 'copy'.
As in the previous refactoring, many thanks to clang-rename for the
help.
This commit is contained in:
parent
6cf6682c54
commit
20f818af12
@ -340,11 +340,11 @@ char *rsa_ssh1_fingerprint(RSAKey *key)
|
|||||||
*/
|
*/
|
||||||
char **rsa_ssh1_fake_all_fingerprints(RSAKey *key)
|
char **rsa_ssh1_fake_all_fingerprints(RSAKey *key)
|
||||||
{
|
{
|
||||||
char **ret = snewn(SSH_N_FPTYPES, char *);
|
char **fingerprints = snewn(SSH_N_FPTYPES, char *);
|
||||||
for (unsigned i = 0; i < SSH_N_FPTYPES; i++)
|
for (unsigned i = 0; i < SSH_N_FPTYPES; i++)
|
||||||
ret[i] = NULL;
|
fingerprints[i] = NULL;
|
||||||
ret[SSH_FPTYPE_MD5] = rsa_ssh1_fingerprint(key);
|
fingerprints[SSH_FPTYPE_MD5] = rsa_ssh1_fingerprint(key);
|
||||||
return ret;
|
return fingerprints;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
14
dialog.c
14
dialog.c
@ -41,15 +41,15 @@ int ctrl_path_compare(const char *p1, const char *p2)
|
|||||||
|
|
||||||
struct controlbox *ctrl_new_box(void)
|
struct controlbox *ctrl_new_box(void)
|
||||||
{
|
{
|
||||||
struct controlbox *ret = snew(struct controlbox);
|
struct controlbox *b = snew(struct controlbox);
|
||||||
|
|
||||||
ret->nctrlsets = ret->ctrlsetsize = 0;
|
b->nctrlsets = b->ctrlsetsize = 0;
|
||||||
ret->ctrlsets = NULL;
|
b->ctrlsets = NULL;
|
||||||
ret->nfrees = ret->freesize = 0;
|
b->nfrees = b->freesize = 0;
|
||||||
ret->frees = NULL;
|
b->frees = NULL;
|
||||||
ret->freefuncs = NULL;
|
b->freefuncs = NULL;
|
||||||
|
|
||||||
return ret;
|
return b;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ctrl_free_box(struct controlbox *b)
|
void ctrl_free_box(struct controlbox *b)
|
||||||
|
116
import.c
116
import.c
@ -339,7 +339,7 @@ static void BinarySink_put_mp_ssh2_from_string(BinarySink *bs, ptrlen str)
|
|||||||
static struct openssh_pem_key *load_openssh_pem_key(BinarySource *src,
|
static struct openssh_pem_key *load_openssh_pem_key(BinarySource *src,
|
||||||
const char **errmsg_p)
|
const char **errmsg_p)
|
||||||
{
|
{
|
||||||
struct openssh_pem_key *ret;
|
struct openssh_pem_key *key;
|
||||||
char *line = NULL;
|
char *line = NULL;
|
||||||
const char *errmsg;
|
const char *errmsg;
|
||||||
char *p;
|
char *p;
|
||||||
@ -347,8 +347,8 @@ static struct openssh_pem_key *load_openssh_pem_key(BinarySource *src,
|
|||||||
char base64_bit[4];
|
char base64_bit[4];
|
||||||
int base64_chars = 0;
|
int base64_chars = 0;
|
||||||
|
|
||||||
ret = snew(struct openssh_pem_key);
|
key = snew(struct openssh_pem_key);
|
||||||
ret->keyblob = strbuf_new_nm();
|
key->keyblob = strbuf_new_nm();
|
||||||
|
|
||||||
if (!(line = bsgetline(src))) {
|
if (!(line = bsgetline(src))) {
|
||||||
errmsg = "unexpected end of file";
|
errmsg = "unexpected end of file";
|
||||||
@ -366,11 +366,11 @@ static struct openssh_pem_key *load_openssh_pem_key(BinarySource *src,
|
|||||||
* base64.
|
* base64.
|
||||||
*/
|
*/
|
||||||
if (!strcmp(line, "-----BEGIN RSA PRIVATE KEY-----")) {
|
if (!strcmp(line, "-----BEGIN RSA PRIVATE KEY-----")) {
|
||||||
ret->keytype = OP_RSA;
|
key->keytype = OP_RSA;
|
||||||
} else if (!strcmp(line, "-----BEGIN DSA PRIVATE KEY-----")) {
|
} else if (!strcmp(line, "-----BEGIN DSA PRIVATE KEY-----")) {
|
||||||
ret->keytype = OP_DSA;
|
key->keytype = OP_DSA;
|
||||||
} else if (!strcmp(line, "-----BEGIN EC PRIVATE KEY-----")) {
|
} else if (!strcmp(line, "-----BEGIN EC PRIVATE KEY-----")) {
|
||||||
ret->keytype = OP_ECDSA;
|
key->keytype = OP_ECDSA;
|
||||||
} else if (!strcmp(line, "-----BEGIN OPENSSH PRIVATE KEY-----")) {
|
} else if (!strcmp(line, "-----BEGIN OPENSSH PRIVATE KEY-----")) {
|
||||||
errmsg = "this is a new-style OpenSSH key";
|
errmsg = "this is a new-style OpenSSH key";
|
||||||
goto error;
|
goto error;
|
||||||
@ -382,8 +382,8 @@ static struct openssh_pem_key *load_openssh_pem_key(BinarySource *src,
|
|||||||
sfree(line);
|
sfree(line);
|
||||||
line = NULL;
|
line = NULL;
|
||||||
|
|
||||||
ret->encrypted = false;
|
key->encrypted = false;
|
||||||
memset(ret->iv, 0, sizeof(ret->iv));
|
memset(key->iv, 0, sizeof(key->iv));
|
||||||
|
|
||||||
headers_done = false;
|
headers_done = false;
|
||||||
while (1) {
|
while (1) {
|
||||||
@ -411,15 +411,15 @@ static struct openssh_pem_key *load_openssh_pem_key(BinarySource *src,
|
|||||||
}
|
}
|
||||||
p += 2;
|
p += 2;
|
||||||
if (!strcmp(p, "ENCRYPTED"))
|
if (!strcmp(p, "ENCRYPTED"))
|
||||||
ret->encrypted = true;
|
key->encrypted = true;
|
||||||
} else if (!strcmp(line, "DEK-Info")) {
|
} else if (!strcmp(line, "DEK-Info")) {
|
||||||
int i, ivlen;
|
int i, ivlen;
|
||||||
|
|
||||||
if (!strncmp(p, "DES-EDE3-CBC,", 13)) {
|
if (!strncmp(p, "DES-EDE3-CBC,", 13)) {
|
||||||
ret->encryption = OP_E_3DES;
|
key->encryption = OP_E_3DES;
|
||||||
ivlen = 8;
|
ivlen = 8;
|
||||||
} else if (!strncmp(p, "AES-128-CBC,", 12)) {
|
} else if (!strncmp(p, "AES-128-CBC,", 12)) {
|
||||||
ret->encryption = OP_E_AES;
|
key->encryption = OP_E_AES;
|
||||||
ivlen = 16;
|
ivlen = 16;
|
||||||
} else {
|
} else {
|
||||||
errmsg = "unsupported cipher";
|
errmsg = "unsupported cipher";
|
||||||
@ -432,7 +432,7 @@ static struct openssh_pem_key *load_openssh_pem_key(BinarySource *src,
|
|||||||
errmsg = "expected more iv data in DEK-Info";
|
errmsg = "expected more iv data in DEK-Info";
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
ret->iv[i] = j;
|
key->iv[i] = j;
|
||||||
p += 2;
|
p += 2;
|
||||||
}
|
}
|
||||||
if (*p) {
|
if (*p) {
|
||||||
@ -459,7 +459,7 @@ static struct openssh_pem_key *load_openssh_pem_key(BinarySource *src,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
put_data(ret->keyblob, out, len);
|
put_data(key->keyblob, out, len);
|
||||||
|
|
||||||
smemclr(out, sizeof(out));
|
smemclr(out, sizeof(out));
|
||||||
}
|
}
|
||||||
@ -472,12 +472,12 @@ static struct openssh_pem_key *load_openssh_pem_key(BinarySource *src,
|
|||||||
line = NULL;
|
line = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!ret->keyblob || ret->keyblob->len == 0) {
|
if (!key->keyblob || key->keyblob->len == 0) {
|
||||||
errmsg = "key body not present";
|
errmsg = "key body not present";
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ret->encrypted && ret->keyblob->len % 8 != 0) {
|
if (key->encrypted && key->keyblob->len % 8 != 0) {
|
||||||
errmsg = "encrypted key blob is not a multiple of "
|
errmsg = "encrypted key blob is not a multiple of "
|
||||||
"cipher block size";
|
"cipher block size";
|
||||||
goto error;
|
goto error;
|
||||||
@ -485,7 +485,7 @@ static struct openssh_pem_key *load_openssh_pem_key(BinarySource *src,
|
|||||||
|
|
||||||
smemclr(base64_bit, sizeof(base64_bit));
|
smemclr(base64_bit, sizeof(base64_bit));
|
||||||
if (errmsg_p) *errmsg_p = NULL;
|
if (errmsg_p) *errmsg_p = NULL;
|
||||||
return ret;
|
return key;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
if (line) {
|
if (line) {
|
||||||
@ -494,11 +494,11 @@ static struct openssh_pem_key *load_openssh_pem_key(BinarySource *src,
|
|||||||
line = NULL;
|
line = NULL;
|
||||||
}
|
}
|
||||||
smemclr(base64_bit, sizeof(base64_bit));
|
smemclr(base64_bit, sizeof(base64_bit));
|
||||||
if (ret) {
|
if (key) {
|
||||||
if (ret->keyblob)
|
if (key->keyblob)
|
||||||
strbuf_free(ret->keyblob);
|
strbuf_free(key->keyblob);
|
||||||
smemclr(ret, sizeof(*ret));
|
smemclr(key, sizeof(*key));
|
||||||
sfree(ret);
|
sfree(key);
|
||||||
}
|
}
|
||||||
if (errmsg_p) *errmsg_p = errmsg;
|
if (errmsg_p) *errmsg_p = errmsg;
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -1119,7 +1119,7 @@ struct openssh_new_key {
|
|||||||
static struct openssh_new_key *load_openssh_new_key(BinarySource *filesrc,
|
static struct openssh_new_key *load_openssh_new_key(BinarySource *filesrc,
|
||||||
const char **errmsg_p)
|
const char **errmsg_p)
|
||||||
{
|
{
|
||||||
struct openssh_new_key *ret;
|
struct openssh_new_key *key;
|
||||||
char *line = NULL;
|
char *line = NULL;
|
||||||
const char *errmsg;
|
const char *errmsg;
|
||||||
char *p;
|
char *p;
|
||||||
@ -1129,8 +1129,8 @@ static struct openssh_new_key *load_openssh_new_key(BinarySource *filesrc,
|
|||||||
ptrlen str;
|
ptrlen str;
|
||||||
unsigned key_index;
|
unsigned key_index;
|
||||||
|
|
||||||
ret = snew(struct openssh_new_key);
|
key = snew(struct openssh_new_key);
|
||||||
ret->keyblob = strbuf_new_nm();
|
key->keyblob = strbuf_new_nm();
|
||||||
|
|
||||||
if (!(line = bsgetline(filesrc))) {
|
if (!(line = bsgetline(filesrc))) {
|
||||||
errmsg = "unexpected end of file";
|
errmsg = "unexpected end of file";
|
||||||
@ -1171,7 +1171,7 @@ static struct openssh_new_key *load_openssh_new_key(BinarySource *filesrc,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
put_data(ret->keyblob, out, len);
|
put_data(key->keyblob, out, len);
|
||||||
|
|
||||||
smemclr(out, sizeof(out));
|
smemclr(out, sizeof(out));
|
||||||
}
|
}
|
||||||
@ -1183,12 +1183,12 @@ static struct openssh_new_key *load_openssh_new_key(BinarySource *filesrc,
|
|||||||
line = NULL;
|
line = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ret->keyblob->len == 0) {
|
if (key->keyblob->len == 0) {
|
||||||
errmsg = "key body not present";
|
errmsg = "key body not present";
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
BinarySource_BARE_INIT_PL(src, ptrlen_from_strbuf(ret->keyblob));
|
BinarySource_BARE_INIT_PL(src, ptrlen_from_strbuf(key->keyblob));
|
||||||
|
|
||||||
if (strcmp(get_asciz(src), "openssh-key-v1") != 0) {
|
if (strcmp(get_asciz(src), "openssh-key-v1") != 0) {
|
||||||
errmsg = "new-style OpenSSH magic number missing\n";
|
errmsg = "new-style OpenSSH magic number missing\n";
|
||||||
@ -1198,11 +1198,11 @@ static struct openssh_new_key *load_openssh_new_key(BinarySource *filesrc,
|
|||||||
/* Cipher name */
|
/* Cipher name */
|
||||||
str = get_string(src);
|
str = get_string(src);
|
||||||
if (ptrlen_eq_string(str, "none")) {
|
if (ptrlen_eq_string(str, "none")) {
|
||||||
ret->cipher = ON_E_NONE;
|
key->cipher = ON_E_NONE;
|
||||||
} else if (ptrlen_eq_string(str, "aes256-cbc")) {
|
} else if (ptrlen_eq_string(str, "aes256-cbc")) {
|
||||||
ret->cipher = ON_E_AES256CBC;
|
key->cipher = ON_E_AES256CBC;
|
||||||
} else if (ptrlen_eq_string(str, "aes256-ctr")) {
|
} else if (ptrlen_eq_string(str, "aes256-ctr")) {
|
||||||
ret->cipher = ON_E_AES256CTR;
|
key->cipher = ON_E_AES256CTR;
|
||||||
} else {
|
} else {
|
||||||
errmsg = get_err(src) ? "no cipher name found" :
|
errmsg = get_err(src) ? "no cipher name found" :
|
||||||
"unrecognised cipher name\n";
|
"unrecognised cipher name\n";
|
||||||
@ -1212,9 +1212,9 @@ static struct openssh_new_key *load_openssh_new_key(BinarySource *filesrc,
|
|||||||
/* Key derivation function name */
|
/* Key derivation function name */
|
||||||
str = get_string(src);
|
str = get_string(src);
|
||||||
if (ptrlen_eq_string(str, "none")) {
|
if (ptrlen_eq_string(str, "none")) {
|
||||||
ret->kdf = ON_K_NONE;
|
key->kdf = ON_K_NONE;
|
||||||
} else if (ptrlen_eq_string(str, "bcrypt")) {
|
} else if (ptrlen_eq_string(str, "bcrypt")) {
|
||||||
ret->kdf = ON_K_BCRYPT;
|
key->kdf = ON_K_BCRYPT;
|
||||||
} else {
|
} else {
|
||||||
errmsg = get_err(src) ? "no kdf name found" :
|
errmsg = get_err(src) ? "no kdf name found" :
|
||||||
"unrecognised kdf name\n";
|
"unrecognised kdf name\n";
|
||||||
@ -1223,7 +1223,7 @@ static struct openssh_new_key *load_openssh_new_key(BinarySource *filesrc,
|
|||||||
|
|
||||||
/* KDF extra options */
|
/* KDF extra options */
|
||||||
str = get_string(src);
|
str = get_string(src);
|
||||||
switch (ret->kdf) {
|
switch (key->kdf) {
|
||||||
case ON_K_NONE:
|
case ON_K_NONE:
|
||||||
if (str.len != 0) {
|
if (str.len != 0) {
|
||||||
errmsg = "expected empty options string for 'none' kdf";
|
errmsg = "expected empty options string for 'none' kdf";
|
||||||
@ -1234,8 +1234,8 @@ static struct openssh_new_key *load_openssh_new_key(BinarySource *filesrc,
|
|||||||
BinarySource opts[1];
|
BinarySource opts[1];
|
||||||
|
|
||||||
BinarySource_BARE_INIT_PL(opts, str);
|
BinarySource_BARE_INIT_PL(opts, str);
|
||||||
ret->kdfopts.bcrypt.salt = get_string(opts);
|
key->kdfopts.bcrypt.salt = get_string(opts);
|
||||||
ret->kdfopts.bcrypt.rounds = get_uint32(opts);
|
key->kdfopts.bcrypt.rounds = get_uint32(opts);
|
||||||
|
|
||||||
if (get_err(opts)) {
|
if (get_err(opts)) {
|
||||||
errmsg = "failed to parse bcrypt options string";
|
errmsg = "failed to parse bcrypt options string";
|
||||||
@ -1257,23 +1257,23 @@ static struct openssh_new_key *load_openssh_new_key(BinarySource *filesrc,
|
|||||||
* 'key_wanted' field is set to a value in the range [0,
|
* 'key_wanted' field is set to a value in the range [0,
|
||||||
* nkeys) by some mechanism.
|
* nkeys) by some mechanism.
|
||||||
*/
|
*/
|
||||||
ret->nkeys = toint(get_uint32(src));
|
key->nkeys = toint(get_uint32(src));
|
||||||
if (ret->nkeys != 1) {
|
if (key->nkeys != 1) {
|
||||||
errmsg = get_err(src) ? "no key count found" :
|
errmsg = get_err(src) ? "no key count found" :
|
||||||
"multiple keys in new-style OpenSSH key file not supported\n";
|
"multiple keys in new-style OpenSSH key file not supported\n";
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
ret->key_wanted = 0;
|
key->key_wanted = 0;
|
||||||
|
|
||||||
/* Read and ignore a string per public key. */
|
/* Read and ignore a string per public key. */
|
||||||
for (key_index = 0; key_index < ret->nkeys; key_index++)
|
for (key_index = 0; key_index < key->nkeys; key_index++)
|
||||||
str = get_string(src);
|
str = get_string(src);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Now we expect a string containing the encrypted part of the
|
* Now we expect a string containing the encrypted part of the
|
||||||
* key file.
|
* key file.
|
||||||
*/
|
*/
|
||||||
ret->private = get_string(src);
|
key->private = get_string(src);
|
||||||
if (get_err(src)) {
|
if (get_err(src)) {
|
||||||
errmsg = "no private key container string found\n";
|
errmsg = "no private key container string found\n";
|
||||||
goto error;
|
goto error;
|
||||||
@ -1285,7 +1285,7 @@ static struct openssh_new_key *load_openssh_new_key(BinarySource *filesrc,
|
|||||||
|
|
||||||
smemclr(base64_bit, sizeof(base64_bit));
|
smemclr(base64_bit, sizeof(base64_bit));
|
||||||
if (errmsg_p) *errmsg_p = NULL;
|
if (errmsg_p) *errmsg_p = NULL;
|
||||||
return ret;
|
return key;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
if (line) {
|
if (line) {
|
||||||
@ -1294,10 +1294,10 @@ static struct openssh_new_key *load_openssh_new_key(BinarySource *filesrc,
|
|||||||
line = NULL;
|
line = NULL;
|
||||||
}
|
}
|
||||||
smemclr(base64_bit, sizeof(base64_bit));
|
smemclr(base64_bit, sizeof(base64_bit));
|
||||||
if (ret) {
|
if (key) {
|
||||||
strbuf_free(ret->keyblob);
|
strbuf_free(key->keyblob);
|
||||||
smemclr(ret, sizeof(*ret));
|
smemclr(key, sizeof(*key));
|
||||||
sfree(ret);
|
sfree(key);
|
||||||
}
|
}
|
||||||
if (errmsg_p) *errmsg_p = errmsg;
|
if (errmsg_p) *errmsg_p = errmsg;
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -1725,7 +1725,7 @@ struct sshcom_key {
|
|||||||
static struct sshcom_key *load_sshcom_key(BinarySource *src,
|
static struct sshcom_key *load_sshcom_key(BinarySource *src,
|
||||||
const char **errmsg_p)
|
const char **errmsg_p)
|
||||||
{
|
{
|
||||||
struct sshcom_key *ret;
|
struct sshcom_key *key;
|
||||||
char *line = NULL;
|
char *line = NULL;
|
||||||
int hdrstart, len;
|
int hdrstart, len;
|
||||||
const char *errmsg;
|
const char *errmsg;
|
||||||
@ -1734,9 +1734,9 @@ static struct sshcom_key *load_sshcom_key(BinarySource *src,
|
|||||||
char base64_bit[4];
|
char base64_bit[4];
|
||||||
int base64_chars = 0;
|
int base64_chars = 0;
|
||||||
|
|
||||||
ret = snew(struct sshcom_key);
|
key = snew(struct sshcom_key);
|
||||||
ret->comment[0] = '\0';
|
key->comment[0] = '\0';
|
||||||
ret->keyblob = strbuf_new_nm();
|
key->keyblob = strbuf_new_nm();
|
||||||
|
|
||||||
if (!(line = bsgetline(src))) {
|
if (!(line = bsgetline(src))) {
|
||||||
errmsg = "unexpected end of file";
|
errmsg = "unexpected end of file";
|
||||||
@ -1803,8 +1803,8 @@ static struct sshcom_key *load_sshcom_key(BinarySource *src,
|
|||||||
p++;
|
p++;
|
||||||
p[strlen(p)-1] = '\0';
|
p[strlen(p)-1] = '\0';
|
||||||
}
|
}
|
||||||
strncpy(ret->comment, p, sizeof(ret->comment));
|
strncpy(key->comment, p, sizeof(key->comment));
|
||||||
ret->comment[sizeof(ret->comment)-1] = '\0';
|
key->comment[sizeof(key->comment)-1] = '\0';
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
headers_done = true;
|
headers_done = true;
|
||||||
@ -1824,7 +1824,7 @@ static struct sshcom_key *load_sshcom_key(BinarySource *src,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
put_data(ret->keyblob, out, len);
|
put_data(key->keyblob, out, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
p++;
|
p++;
|
||||||
@ -1835,13 +1835,13 @@ static struct sshcom_key *load_sshcom_key(BinarySource *src,
|
|||||||
line = NULL;
|
line = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ret->keyblob->len == 0) {
|
if (key->keyblob->len == 0) {
|
||||||
errmsg = "key body not present";
|
errmsg = "key body not present";
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (errmsg_p) *errmsg_p = NULL;
|
if (errmsg_p) *errmsg_p = NULL;
|
||||||
return ret;
|
return key;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
if (line) {
|
if (line) {
|
||||||
@ -1849,10 +1849,10 @@ static struct sshcom_key *load_sshcom_key(BinarySource *src,
|
|||||||
sfree(line);
|
sfree(line);
|
||||||
line = NULL;
|
line = NULL;
|
||||||
}
|
}
|
||||||
if (ret) {
|
if (key) {
|
||||||
strbuf_free(ret->keyblob);
|
strbuf_free(key->keyblob);
|
||||||
smemclr(ret, sizeof(*ret));
|
smemclr(key, sizeof(*key));
|
||||||
sfree(ret);
|
sfree(key);
|
||||||
}
|
}
|
||||||
if (errmsg_p) *errmsg_p = errmsg;
|
if (errmsg_p) *errmsg_p = errmsg;
|
||||||
return NULL;
|
return NULL;
|
||||||
|
14
pageant.c
14
pageant.c
@ -2673,14 +2673,14 @@ int pageant_sign(struct pageant_pubkey *key, ptrlen message, strbuf *out,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
struct pageant_pubkey *pageant_pubkey_copy(struct pageant_pubkey *key)
|
struct pageant_pubkey *pageant_pubkey_copy(struct pageant_pubkey *orig)
|
||||||
{
|
{
|
||||||
struct pageant_pubkey *ret = snew(struct pageant_pubkey);
|
struct pageant_pubkey *copy = snew(struct pageant_pubkey);
|
||||||
ret->blob = strbuf_new();
|
copy->blob = strbuf_new();
|
||||||
put_data(ret->blob, key->blob->s, key->blob->len);
|
put_data(copy->blob, orig->blob->s, orig->blob->len);
|
||||||
ret->comment = key->comment ? dupstr(key->comment) : NULL;
|
copy->comment = orig->comment ? dupstr(orig->comment) : NULL;
|
||||||
ret->ssh_version = key->ssh_version;
|
copy->ssh_version = orig->ssh_version;
|
||||||
return ret;
|
return copy;
|
||||||
}
|
}
|
||||||
|
|
||||||
void pageant_pubkey_free(struct pageant_pubkey *key)
|
void pageant_pubkey_free(struct pageant_pubkey *key)
|
||||||
|
@ -54,10 +54,10 @@ struct crcda_ctx {
|
|||||||
|
|
||||||
struct crcda_ctx *crcda_make_context(void)
|
struct crcda_ctx *crcda_make_context(void)
|
||||||
{
|
{
|
||||||
struct crcda_ctx *ret = snew(struct crcda_ctx);
|
struct crcda_ctx *ctx = snew(struct crcda_ctx);
|
||||||
ret->h = NULL;
|
ctx->h = NULL;
|
||||||
ret->n = HASH_MINSIZE / HASH_ENTRYSIZE;
|
ctx->n = HASH_MINSIZE / HASH_ENTRYSIZE;
|
||||||
return ret;
|
return ctx;
|
||||||
}
|
}
|
||||||
|
|
||||||
void crcda_free_context(struct crcda_ctx *ctx)
|
void crcda_free_context(struct crcda_ctx *ctx)
|
||||||
|
42
ssh/sftp.c
42
ssh/sftp.c
@ -736,7 +736,7 @@ struct fxp_names *fxp_readdir_recv(struct sftp_packet *pktin,
|
|||||||
{
|
{
|
||||||
sfree(req);
|
sfree(req);
|
||||||
if (pktin->type == SSH_FXP_NAME) {
|
if (pktin->type == SSH_FXP_NAME) {
|
||||||
struct fxp_names *ret;
|
struct fxp_names *names;
|
||||||
unsigned long i;
|
unsigned long i;
|
||||||
|
|
||||||
i = get_uint32(pktin);
|
i = get_uint32(pktin);
|
||||||
@ -766,28 +766,28 @@ struct fxp_names *fxp_readdir_recv(struct sftp_packet *pktin,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = snew(struct fxp_names);
|
names = snew(struct fxp_names);
|
||||||
ret->nnames = i;
|
names->nnames = i;
|
||||||
ret->names = snewn(ret->nnames, struct fxp_name);
|
names->names = snewn(names->nnames, struct fxp_name);
|
||||||
for (i = 0; i < (unsigned long)ret->nnames; i++) {
|
for (i = 0; i < (unsigned long)names->nnames; i++) {
|
||||||
ret->names[i].filename = mkstr(get_string(pktin));
|
names->names[i].filename = mkstr(get_string(pktin));
|
||||||
ret->names[i].longname = mkstr(get_string(pktin));
|
names->names[i].longname = mkstr(get_string(pktin));
|
||||||
get_fxp_attrs(pktin, &ret->names[i].attrs);
|
get_fxp_attrs(pktin, &names->names[i].attrs);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (get_err(pktin)) {
|
if (get_err(pktin)) {
|
||||||
fxp_internal_error("malformed FXP_NAME packet");
|
fxp_internal_error("malformed FXP_NAME packet");
|
||||||
for (i = 0; i < (unsigned long)ret->nnames; i++) {
|
for (i = 0; i < (unsigned long)names->nnames; i++) {
|
||||||
sfree(ret->names[i].filename);
|
sfree(names->names[i].filename);
|
||||||
sfree(ret->names[i].longname);
|
sfree(names->names[i].longname);
|
||||||
}
|
}
|
||||||
sfree(ret->names);
|
sfree(names->names);
|
||||||
sfree(ret);
|
sfree(names);
|
||||||
sfree(pktin);
|
sfree(pktin);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
sftp_pkt_free(pktin);
|
sftp_pkt_free(pktin);
|
||||||
return ret;
|
return names;
|
||||||
} else {
|
} else {
|
||||||
fxp_got_status(pktin);
|
fxp_got_status(pktin);
|
||||||
sftp_pkt_free(pktin);
|
sftp_pkt_free(pktin);
|
||||||
@ -840,14 +840,14 @@ void fxp_free_names(struct fxp_names *names)
|
|||||||
/*
|
/*
|
||||||
* Duplicate an fxp_name structure.
|
* Duplicate an fxp_name structure.
|
||||||
*/
|
*/
|
||||||
struct fxp_name *fxp_dup_name(struct fxp_name *name)
|
struct fxp_name *fxp_dup_name(struct fxp_name *orig)
|
||||||
{
|
{
|
||||||
struct fxp_name *ret;
|
struct fxp_name *copy;
|
||||||
ret = snew(struct fxp_name);
|
copy = snew(struct fxp_name);
|
||||||
ret->filename = dupstr(name->filename);
|
copy->filename = dupstr(orig->filename);
|
||||||
ret->longname = dupstr(name->longname);
|
copy->longname = dupstr(orig->longname);
|
||||||
ret->attrs = name->attrs; /* structure copy */
|
copy->attrs = orig->attrs; /* structure copy */
|
||||||
return ret;
|
return copy;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
22
sshpubk.c
22
sshpubk.c
@ -713,7 +713,7 @@ ssh2_userkey *ppk_load_s(BinarySource *src, const char *passphrase,
|
|||||||
{
|
{
|
||||||
char header[40], *b, *encryption, *comment, *mac;
|
char header[40], *b, *encryption, *comment, *mac;
|
||||||
const ssh_keyalg *alg;
|
const ssh_keyalg *alg;
|
||||||
ssh2_userkey *ret;
|
ssh2_userkey *ukey;
|
||||||
strbuf *public_blob, *private_blob, *cipher_mac_keys_blob;
|
strbuf *public_blob, *private_blob, *cipher_mac_keys_blob;
|
||||||
strbuf *passphrase_salt = strbuf_new();
|
strbuf *passphrase_salt = strbuf_new();
|
||||||
ptrlen cipherkey, cipheriv, mackey;
|
ptrlen cipherkey, cipheriv, mackey;
|
||||||
@ -724,7 +724,7 @@ ssh2_userkey *ppk_load_s(BinarySource *src, const char *passphrase,
|
|||||||
const char *error = NULL;
|
const char *error = NULL;
|
||||||
ppk_save_parameters params;
|
ppk_save_parameters params;
|
||||||
|
|
||||||
ret = NULL; /* return NULL for most errors */
|
ukey = NULL; /* return NULL for most errors */
|
||||||
encryption = comment = mac = NULL;
|
encryption = comment = mac = NULL;
|
||||||
public_blob = private_blob = cipher_mac_keys_blob = NULL;
|
public_blob = private_blob = cipher_mac_keys_blob = NULL;
|
||||||
|
|
||||||
@ -960,10 +960,10 @@ ssh2_userkey *ppk_load_s(BinarySource *src, const char *passphrase,
|
|||||||
* unencrypted. Otherwise, it means Wrong Passphrase. */
|
* unencrypted. Otherwise, it means Wrong Passphrase. */
|
||||||
if (ciphertype->keylen != 0) {
|
if (ciphertype->keylen != 0) {
|
||||||
error = "wrong passphrase";
|
error = "wrong passphrase";
|
||||||
ret = SSH2_WRONG_PASSPHRASE;
|
ukey = SSH2_WRONG_PASSPHRASE;
|
||||||
} else {
|
} else {
|
||||||
error = "MAC failed";
|
error = "MAC failed";
|
||||||
ret = NULL;
|
ukey = NULL;
|
||||||
}
|
}
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
@ -972,15 +972,15 @@ ssh2_userkey *ppk_load_s(BinarySource *src, const char *passphrase,
|
|||||||
/*
|
/*
|
||||||
* Create and return the key.
|
* Create and return the key.
|
||||||
*/
|
*/
|
||||||
ret = snew(ssh2_userkey);
|
ukey = snew(ssh2_userkey);
|
||||||
ret->comment = comment;
|
ukey->comment = comment;
|
||||||
comment = NULL;
|
comment = NULL;
|
||||||
ret->key = ssh_key_new_priv(
|
ukey->key = ssh_key_new_priv(
|
||||||
alg, ptrlen_from_strbuf(public_blob),
|
alg, ptrlen_from_strbuf(public_blob),
|
||||||
ptrlen_from_strbuf(private_blob));
|
ptrlen_from_strbuf(private_blob));
|
||||||
if (!ret->key) {
|
if (!ukey->key) {
|
||||||
sfree(ret);
|
sfree(ukey);
|
||||||
ret = NULL;
|
ukey = NULL;
|
||||||
error = "createkey failed";
|
error = "createkey failed";
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
@ -1005,7 +1005,7 @@ ssh2_userkey *ppk_load_s(BinarySource *src, const char *passphrase,
|
|||||||
strbuf_free(passphrase_salt);
|
strbuf_free(passphrase_salt);
|
||||||
if (errorstr)
|
if (errorstr)
|
||||||
*errorstr = error;
|
*errorstr = error;
|
||||||
return ret;
|
return ukey;
|
||||||
}
|
}
|
||||||
|
|
||||||
ssh2_userkey *ppk_load_f(const Filename *filename, const char *passphrase,
|
ssh2_userkey *ppk_load_f(const Filename *filename, const char *passphrase,
|
||||||
|
342
unix/network.c
342
unix/network.c
@ -271,18 +271,18 @@ SockAddr *sk_namelookup(const char *host, char **canonicalname,
|
|||||||
|
|
||||||
SockAddr *sk_nonamelookup(const char *host)
|
SockAddr *sk_nonamelookup(const char *host)
|
||||||
{
|
{
|
||||||
SockAddr *ret = snew(SockAddr);
|
SockAddr *addr = snew(SockAddr);
|
||||||
ret->error = NULL;
|
addr->error = NULL;
|
||||||
ret->superfamily = UNRESOLVED;
|
addr->superfamily = UNRESOLVED;
|
||||||
strncpy(ret->hostname, host, lenof(ret->hostname));
|
strncpy(addr->hostname, host, lenof(addr->hostname));
|
||||||
ret->hostname[lenof(ret->hostname)-1] = '\0';
|
addr->hostname[lenof(addr->hostname)-1] = '\0';
|
||||||
#ifndef NO_IPV6
|
#ifndef NO_IPV6
|
||||||
ret->ais = NULL;
|
addr->ais = NULL;
|
||||||
#else
|
#else
|
||||||
ret->addresses = NULL;
|
ret->addresses = NULL;
|
||||||
#endif
|
#endif
|
||||||
ret->refcount = 1;
|
addr->refcount = 1;
|
||||||
return ret;
|
return addr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool sk_nextaddr(SockAddr *addr, SockAddrStep *step)
|
static bool sk_nextaddr(SockAddr *addr, SockAddrStep *step)
|
||||||
@ -505,42 +505,42 @@ static const SocketVtable NetSocket_sockvt = {
|
|||||||
static Socket *sk_net_accept(accept_ctx_t ctx, Plug *plug)
|
static Socket *sk_net_accept(accept_ctx_t ctx, Plug *plug)
|
||||||
{
|
{
|
||||||
int sockfd = ctx.i;
|
int sockfd = ctx.i;
|
||||||
NetSocket *ret;
|
NetSocket *s;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create NetSocket structure.
|
* Create NetSocket structure.
|
||||||
*/
|
*/
|
||||||
ret = snew(NetSocket);
|
s = snew(NetSocket);
|
||||||
ret->sock.vt = &NetSocket_sockvt;
|
s->sock.vt = &NetSocket_sockvt;
|
||||||
ret->error = NULL;
|
s->error = NULL;
|
||||||
ret->plug = plug;
|
s->plug = plug;
|
||||||
bufchain_init(&ret->output_data);
|
bufchain_init(&s->output_data);
|
||||||
ret->writable = true; /* to start with */
|
s->writable = true; /* to start with */
|
||||||
ret->sending_oob = 0;
|
s->sending_oob = 0;
|
||||||
ret->frozen = true;
|
s->frozen = true;
|
||||||
ret->localhost_only = false; /* unused, but best init anyway */
|
s->localhost_only = false; /* unused, but best init anyway */
|
||||||
ret->pending_error = 0;
|
s->pending_error = 0;
|
||||||
ret->oobpending = false;
|
s->oobpending = false;
|
||||||
ret->outgoingeof = EOF_NO;
|
s->outgoingeof = EOF_NO;
|
||||||
ret->incomingeof = false;
|
s->incomingeof = false;
|
||||||
ret->listener = false;
|
s->listener = false;
|
||||||
ret->parent = ret->child = NULL;
|
s->parent = s->child = NULL;
|
||||||
ret->addr = NULL;
|
s->addr = NULL;
|
||||||
ret->connected = true;
|
s->connected = true;
|
||||||
|
|
||||||
ret->s = sockfd;
|
s->s = sockfd;
|
||||||
|
|
||||||
if (ret->s < 0) {
|
if (s->s < 0) {
|
||||||
ret->error = strerror(errno);
|
s->error = strerror(errno);
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret->oobinline = false;
|
s->oobinline = false;
|
||||||
|
|
||||||
uxsel_tell(ret);
|
uxsel_tell(s);
|
||||||
add234(sktree, ret);
|
add234(sktree, s);
|
||||||
|
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int try_connect(NetSocket *sock)
|
static int try_connect(NetSocket *sock)
|
||||||
@ -750,51 +750,51 @@ static int try_connect(NetSocket *sock)
|
|||||||
Socket *sk_new(SockAddr *addr, int port, bool privport, bool oobinline,
|
Socket *sk_new(SockAddr *addr, int port, bool privport, bool oobinline,
|
||||||
bool nodelay, bool keepalive, Plug *plug)
|
bool nodelay, bool keepalive, Plug *plug)
|
||||||
{
|
{
|
||||||
NetSocket *ret;
|
NetSocket *s;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create NetSocket structure.
|
* Create NetSocket structure.
|
||||||
*/
|
*/
|
||||||
ret = snew(NetSocket);
|
s = snew(NetSocket);
|
||||||
ret->sock.vt = &NetSocket_sockvt;
|
s->sock.vt = &NetSocket_sockvt;
|
||||||
ret->error = NULL;
|
s->error = NULL;
|
||||||
ret->plug = plug;
|
s->plug = plug;
|
||||||
bufchain_init(&ret->output_data);
|
bufchain_init(&s->output_data);
|
||||||
ret->connected = false; /* to start with */
|
s->connected = false; /* to start with */
|
||||||
ret->writable = false; /* to start with */
|
s->writable = false; /* to start with */
|
||||||
ret->sending_oob = 0;
|
s->sending_oob = 0;
|
||||||
ret->frozen = false;
|
s->frozen = false;
|
||||||
ret->localhost_only = false; /* unused, but best init anyway */
|
s->localhost_only = false; /* unused, but best init anyway */
|
||||||
ret->pending_error = 0;
|
s->pending_error = 0;
|
||||||
ret->parent = ret->child = NULL;
|
s->parent = s->child = NULL;
|
||||||
ret->oobpending = false;
|
s->oobpending = false;
|
||||||
ret->outgoingeof = EOF_NO;
|
s->outgoingeof = EOF_NO;
|
||||||
ret->incomingeof = false;
|
s->incomingeof = false;
|
||||||
ret->listener = false;
|
s->listener = false;
|
||||||
ret->addr = addr;
|
s->addr = addr;
|
||||||
START_STEP(ret->addr, ret->step);
|
START_STEP(s->addr, s->step);
|
||||||
ret->s = -1;
|
s->s = -1;
|
||||||
ret->oobinline = oobinline;
|
s->oobinline = oobinline;
|
||||||
ret->nodelay = nodelay;
|
s->nodelay = nodelay;
|
||||||
ret->keepalive = keepalive;
|
s->keepalive = keepalive;
|
||||||
ret->privport = privport;
|
s->privport = privport;
|
||||||
ret->port = port;
|
s->port = port;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
err = try_connect(ret);
|
err = try_connect(s);
|
||||||
} while (err && sk_nextaddr(ret->addr, &ret->step));
|
} while (err && sk_nextaddr(s->addr, &s->step));
|
||||||
|
|
||||||
if (err)
|
if (err)
|
||||||
ret->error = strerror(err);
|
s->error = strerror(err);
|
||||||
|
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
|
Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
|
||||||
bool local_host_only, int orig_address_family)
|
bool local_host_only, int orig_address_family)
|
||||||
{
|
{
|
||||||
int s;
|
int fd;
|
||||||
#ifndef NO_IPV6
|
#ifndef NO_IPV6
|
||||||
struct addrinfo hints, *ai = NULL;
|
struct addrinfo hints, *ai = NULL;
|
||||||
char portstr[6];
|
char portstr[6];
|
||||||
@ -802,7 +802,7 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
|
|||||||
union sockaddr_union u;
|
union sockaddr_union u;
|
||||||
union sockaddr_union *addr;
|
union sockaddr_union *addr;
|
||||||
int addrlen;
|
int addrlen;
|
||||||
NetSocket *ret;
|
NetSocket *s;
|
||||||
int retcode;
|
int retcode;
|
||||||
int address_family;
|
int address_family;
|
||||||
int on = 1;
|
int on = 1;
|
||||||
@ -810,23 +810,23 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
|
|||||||
/*
|
/*
|
||||||
* Create NetSocket structure.
|
* Create NetSocket structure.
|
||||||
*/
|
*/
|
||||||
ret = snew(NetSocket);
|
s = snew(NetSocket);
|
||||||
ret->sock.vt = &NetSocket_sockvt;
|
s->sock.vt = &NetSocket_sockvt;
|
||||||
ret->error = NULL;
|
s->error = NULL;
|
||||||
ret->plug = plug;
|
s->plug = plug;
|
||||||
bufchain_init(&ret->output_data);
|
bufchain_init(&s->output_data);
|
||||||
ret->writable = false; /* to start with */
|
s->writable = false; /* to start with */
|
||||||
ret->sending_oob = 0;
|
s->sending_oob = 0;
|
||||||
ret->frozen = false;
|
s->frozen = false;
|
||||||
ret->localhost_only = local_host_only;
|
s->localhost_only = local_host_only;
|
||||||
ret->pending_error = 0;
|
s->pending_error = 0;
|
||||||
ret->parent = ret->child = NULL;
|
s->parent = s->child = NULL;
|
||||||
ret->oobpending = false;
|
s->oobpending = false;
|
||||||
ret->outgoingeof = EOF_NO;
|
s->outgoingeof = EOF_NO;
|
||||||
ret->incomingeof = false;
|
s->incomingeof = false;
|
||||||
ret->listener = true;
|
s->listener = true;
|
||||||
ret->addr = NULL;
|
s->addr = NULL;
|
||||||
ret->s = -1;
|
s->s = -1;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Translate address_family from platform-independent constants
|
* Translate address_family from platform-independent constants
|
||||||
@ -850,30 +850,30 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
|
|||||||
/*
|
/*
|
||||||
* Open socket.
|
* Open socket.
|
||||||
*/
|
*/
|
||||||
s = socket(address_family, SOCK_STREAM, 0);
|
fd = socket(address_family, SOCK_STREAM, 0);
|
||||||
|
|
||||||
#ifndef NO_IPV6
|
#ifndef NO_IPV6
|
||||||
/* If the host doesn't support IPv6 try fallback to IPv4. */
|
/* If the host doesn't support IPv6 try fallback to IPv4. */
|
||||||
if (s < 0 && address_family == AF_INET6) {
|
if (fd < 0 && address_family == AF_INET6) {
|
||||||
address_family = AF_INET;
|
address_family = AF_INET;
|
||||||
s = socket(address_family, SOCK_STREAM, 0);
|
fd = socket(address_family, SOCK_STREAM, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (s < 0) {
|
if (fd < 0) {
|
||||||
ret->error = strerror(errno);
|
s->error = strerror(errno);
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
cloexec(s);
|
cloexec(fd);
|
||||||
|
|
||||||
ret->oobinline = false;
|
s->oobinline = false;
|
||||||
|
|
||||||
if (setsockopt(s, SOL_SOCKET, SO_REUSEADDR,
|
if (setsockopt(fd, SOL_SOCKET, SO_REUSEADDR,
|
||||||
(const char *)&on, sizeof(on)) < 0) {
|
(const char *)&on, sizeof(on)) < 0) {
|
||||||
ret->error = strerror(errno);
|
s->error = strerror(errno);
|
||||||
close(s);
|
close(fd);
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
retcode = -1;
|
retcode = -1;
|
||||||
@ -941,7 +941,7 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
retcode = bind(s, &addr->sa, addrlen);
|
retcode = bind(fd, &addr->sa, addrlen);
|
||||||
|
|
||||||
#ifndef NO_IPV6
|
#ifndef NO_IPV6
|
||||||
if (ai)
|
if (ai)
|
||||||
@ -949,15 +949,15 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (retcode < 0) {
|
if (retcode < 0) {
|
||||||
close(s);
|
close(fd);
|
||||||
ret->error = strerror(errno);
|
s->error = strerror(errno);
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (listen(s, SOMAXCONN) < 0) {
|
if (listen(fd, SOMAXCONN) < 0) {
|
||||||
close(s);
|
close(fd);
|
||||||
ret->error = strerror(errno);
|
s->error = strerror(errno);
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef NO_IPV6
|
#ifndef NO_IPV6
|
||||||
@ -975,25 +975,25 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
|
|||||||
|
|
||||||
if (other) {
|
if (other) {
|
||||||
if (!other->error) {
|
if (!other->error) {
|
||||||
other->parent = ret;
|
other->parent = s;
|
||||||
ret->child = other;
|
s->child = other;
|
||||||
} else {
|
} else {
|
||||||
/* If we couldn't create a listening socket on IPv4 as well
|
/* If we couldn't create a listening socket on IPv4 as well
|
||||||
* as IPv6, we must return an error overall. */
|
* as IPv6, we must return an error overall. */
|
||||||
close(s);
|
close(fd);
|
||||||
sfree(ret);
|
sfree(s);
|
||||||
return &other->sock;
|
return &other->sock;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
ret->s = s;
|
s->s = fd;
|
||||||
|
|
||||||
uxsel_tell(ret);
|
uxsel_tell(s);
|
||||||
add234(sktree, ret);
|
add234(sktree, s);
|
||||||
|
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void sk_net_close(Socket *sock)
|
static void sk_net_close(Socket *sock)
|
||||||
@ -1612,107 +1612,107 @@ char *get_hostname(void)
|
|||||||
|
|
||||||
SockAddr *platform_get_x11_unix_address(const char *sockpath, int displaynum)
|
SockAddr *platform_get_x11_unix_address(const char *sockpath, int displaynum)
|
||||||
{
|
{
|
||||||
SockAddr *ret = snew(SockAddr);
|
SockAddr *addr = snew(SockAddr);
|
||||||
int n;
|
int n;
|
||||||
|
|
||||||
memset(ret, 0, sizeof *ret);
|
memset(addr, 0, sizeof *addr);
|
||||||
ret->superfamily = UNIX;
|
addr->superfamily = UNIX;
|
||||||
/*
|
/*
|
||||||
* In special circumstances (notably Mac OS X Leopard), we'll
|
* In special circumstances (notably Mac OS X Leopard), we'll
|
||||||
* have been passed an explicit Unix socket path.
|
* have been passed an explicit Unix socket path.
|
||||||
*/
|
*/
|
||||||
if (sockpath) {
|
if (sockpath) {
|
||||||
n = snprintf(ret->hostname, sizeof ret->hostname,
|
n = snprintf(addr->hostname, sizeof addr->hostname,
|
||||||
"%s", sockpath);
|
"%s", sockpath);
|
||||||
} else {
|
} else {
|
||||||
n = snprintf(ret->hostname, sizeof ret->hostname,
|
n = snprintf(addr->hostname, sizeof addr->hostname,
|
||||||
"%s%d", X11_UNIX_PATH, displaynum);
|
"%s%d", X11_UNIX_PATH, displaynum);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (n < 0)
|
if (n < 0)
|
||||||
ret->error = "snprintf failed";
|
addr->error = "snprintf failed";
|
||||||
else if (n >= sizeof ret->hostname)
|
else if (n >= sizeof addr->hostname)
|
||||||
ret->error = "X11 UNIX name too long";
|
addr->error = "X11 UNIX name too long";
|
||||||
|
|
||||||
#ifndef NO_IPV6
|
#ifndef NO_IPV6
|
||||||
ret->ais = NULL;
|
addr->ais = NULL;
|
||||||
#else
|
#else
|
||||||
ret->addresses = NULL;
|
ret->addresses = NULL;
|
||||||
ret->naddresses = 0;
|
ret->naddresses = 0;
|
||||||
#endif
|
#endif
|
||||||
ret->refcount = 1;
|
addr->refcount = 1;
|
||||||
return ret;
|
return addr;
|
||||||
}
|
}
|
||||||
|
|
||||||
SockAddr *unix_sock_addr(const char *path)
|
SockAddr *unix_sock_addr(const char *path)
|
||||||
{
|
{
|
||||||
SockAddr *ret = snew(SockAddr);
|
SockAddr *addr = snew(SockAddr);
|
||||||
int n;
|
int n;
|
||||||
|
|
||||||
memset(ret, 0, sizeof *ret);
|
memset(addr, 0, sizeof *addr);
|
||||||
ret->superfamily = UNIX;
|
addr->superfamily = UNIX;
|
||||||
n = snprintf(ret->hostname, sizeof ret->hostname, "%s", path);
|
n = snprintf(addr->hostname, sizeof addr->hostname, "%s", path);
|
||||||
|
|
||||||
if (n < 0)
|
if (n < 0)
|
||||||
ret->error = "snprintf failed";
|
addr->error = "snprintf failed";
|
||||||
else if (n >= sizeof ret->hostname ||
|
else if (n >= sizeof addr->hostname ||
|
||||||
n >= sizeof(((struct sockaddr_un *)0)->sun_path))
|
n >= sizeof(((struct sockaddr_un *)0)->sun_path))
|
||||||
ret->error = "socket pathname too long";
|
addr->error = "socket pathname too long";
|
||||||
|
|
||||||
#ifndef NO_IPV6
|
#ifndef NO_IPV6
|
||||||
ret->ais = NULL;
|
addr->ais = NULL;
|
||||||
#else
|
#else
|
||||||
ret->addresses = NULL;
|
ret->addresses = NULL;
|
||||||
ret->naddresses = 0;
|
ret->naddresses = 0;
|
||||||
#endif
|
#endif
|
||||||
ret->refcount = 1;
|
addr->refcount = 1;
|
||||||
return ret;
|
return addr;
|
||||||
}
|
}
|
||||||
|
|
||||||
Socket *new_unix_listener(SockAddr *listenaddr, Plug *plug)
|
Socket *new_unix_listener(SockAddr *listenaddr, Plug *plug)
|
||||||
{
|
{
|
||||||
int s;
|
int fd;
|
||||||
union sockaddr_union u;
|
union sockaddr_union u;
|
||||||
union sockaddr_union *addr;
|
union sockaddr_union *addr;
|
||||||
int addrlen;
|
int addrlen;
|
||||||
NetSocket *ret;
|
NetSocket *s;
|
||||||
int retcode;
|
int retcode;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create NetSocket structure.
|
* Create NetSocket structure.
|
||||||
*/
|
*/
|
||||||
ret = snew(NetSocket);
|
s = snew(NetSocket);
|
||||||
ret->sock.vt = &NetSocket_sockvt;
|
s->sock.vt = &NetSocket_sockvt;
|
||||||
ret->error = NULL;
|
s->error = NULL;
|
||||||
ret->plug = plug;
|
s->plug = plug;
|
||||||
bufchain_init(&ret->output_data);
|
bufchain_init(&s->output_data);
|
||||||
ret->writable = false; /* to start with */
|
s->writable = false; /* to start with */
|
||||||
ret->sending_oob = 0;
|
s->sending_oob = 0;
|
||||||
ret->frozen = false;
|
s->frozen = false;
|
||||||
ret->localhost_only = true;
|
s->localhost_only = true;
|
||||||
ret->pending_error = 0;
|
s->pending_error = 0;
|
||||||
ret->parent = ret->child = NULL;
|
s->parent = s->child = NULL;
|
||||||
ret->oobpending = false;
|
s->oobpending = false;
|
||||||
ret->outgoingeof = EOF_NO;
|
s->outgoingeof = EOF_NO;
|
||||||
ret->incomingeof = false;
|
s->incomingeof = false;
|
||||||
ret->listener = true;
|
s->listener = true;
|
||||||
ret->addr = listenaddr;
|
s->addr = listenaddr;
|
||||||
ret->s = -1;
|
s->s = -1;
|
||||||
|
|
||||||
assert(listenaddr->superfamily == UNIX);
|
assert(listenaddr->superfamily == UNIX);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Open socket.
|
* Open socket.
|
||||||
*/
|
*/
|
||||||
s = socket(AF_UNIX, SOCK_STREAM, 0);
|
fd = socket(AF_UNIX, SOCK_STREAM, 0);
|
||||||
if (s < 0) {
|
if (fd < 0) {
|
||||||
ret->error = strerror(errno);
|
s->error = strerror(errno);
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
cloexec(s);
|
cloexec(fd);
|
||||||
|
|
||||||
ret->oobinline = false;
|
s->oobinline = false;
|
||||||
|
|
||||||
memset(&u, '\0', sizeof(u));
|
memset(&u, '\0', sizeof(u));
|
||||||
u.su.sun_family = AF_UNIX;
|
u.su.sun_family = AF_UNIX;
|
||||||
@ -1728,28 +1728,28 @@ Socket *new_unix_listener(SockAddr *listenaddr, Plug *plug)
|
|||||||
addrlen = sizeof(u.su);
|
addrlen = sizeof(u.su);
|
||||||
|
|
||||||
if (unlink(u.su.sun_path) < 0 && errno != ENOENT) {
|
if (unlink(u.su.sun_path) < 0 && errno != ENOENT) {
|
||||||
close(s);
|
close(fd);
|
||||||
ret->error = strerror(errno);
|
s->error = strerror(errno);
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
retcode = bind(s, &addr->sa, addrlen);
|
retcode = bind(fd, &addr->sa, addrlen);
|
||||||
if (retcode < 0) {
|
if (retcode < 0) {
|
||||||
close(s);
|
close(fd);
|
||||||
ret->error = strerror(errno);
|
s->error = strerror(errno);
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (listen(s, SOMAXCONN) < 0) {
|
if (listen(fd, SOMAXCONN) < 0) {
|
||||||
close(s);
|
close(fd);
|
||||||
ret->error = strerror(errno);
|
s->error = strerror(errno);
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret->s = s;
|
s->s = fd;
|
||||||
|
|
||||||
uxsel_tell(ret);
|
uxsel_tell(s);
|
||||||
add234(sktree, ret);
|
add234(sktree, s);
|
||||||
|
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
@ -12,17 +12,17 @@ struct printer_job_tag {
|
|||||||
|
|
||||||
printer_job *printer_start_job(char *printer)
|
printer_job *printer_start_job(char *printer)
|
||||||
{
|
{
|
||||||
printer_job *ret = snew(printer_job);
|
printer_job *pj = snew(printer_job);
|
||||||
/*
|
/*
|
||||||
* On Unix, we treat the printer string as the name of a
|
* On Unix, we treat the printer string as the name of a
|
||||||
* command to pipe to - typically lpr, of course.
|
* command to pipe to - typically lpr, of course.
|
||||||
*/
|
*/
|
||||||
ret->fp = popen(printer, "w");
|
pj->fp = popen(printer, "w");
|
||||||
if (!ret->fp) {
|
if (!pj->fp) {
|
||||||
sfree(ret);
|
sfree(pj);
|
||||||
ret = NULL;
|
pj = NULL;
|
||||||
}
|
}
|
||||||
return ret;
|
return pj;
|
||||||
}
|
}
|
||||||
|
|
||||||
void printer_job_data(printer_job *pj, const void *data, size_t len)
|
void printer_job_data(printer_job *pj, const void *data, size_t len)
|
||||||
|
51
unix/sftp.c
51
unix/sftp.c
@ -125,14 +125,14 @@ RFile *open_existing_file(const char *name, uint64_t *size,
|
|||||||
long *perms)
|
long *perms)
|
||||||
{
|
{
|
||||||
int fd;
|
int fd;
|
||||||
RFile *ret;
|
RFile *f;
|
||||||
|
|
||||||
fd = open(name, O_RDONLY);
|
fd = open(name, O_RDONLY);
|
||||||
if (fd < 0)
|
if (fd < 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
ret = snew(RFile);
|
f = snew(RFile);
|
||||||
ret->fd = fd;
|
f->fd = fd;
|
||||||
|
|
||||||
if (size || mtime || atime || perms) {
|
if (size || mtime || atime || perms) {
|
||||||
struct stat statbuf;
|
struct stat statbuf;
|
||||||
@ -154,7 +154,7 @@ RFile *open_existing_file(const char *name, uint64_t *size,
|
|||||||
*perms = statbuf.st_mode;
|
*perms = statbuf.st_mode;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return f;
|
||||||
}
|
}
|
||||||
|
|
||||||
int read_from_file(RFile *f, void *buffer, int length)
|
int read_from_file(RFile *f, void *buffer, int length)
|
||||||
@ -176,33 +176,33 @@ struct WFile {
|
|||||||
WFile *open_new_file(const char *name, long perms)
|
WFile *open_new_file(const char *name, long perms)
|
||||||
{
|
{
|
||||||
int fd;
|
int fd;
|
||||||
WFile *ret;
|
WFile *f;
|
||||||
|
|
||||||
fd = open(name, O_CREAT | O_TRUNC | O_WRONLY,
|
fd = open(name, O_CREAT | O_TRUNC | O_WRONLY,
|
||||||
(mode_t)(perms ? perms : 0666));
|
(mode_t)(perms ? perms : 0666));
|
||||||
if (fd < 0)
|
if (fd < 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
ret = snew(WFile);
|
f = snew(WFile);
|
||||||
ret->fd = fd;
|
f->fd = fd;
|
||||||
ret->name = dupstr(name);
|
f->name = dupstr(name);
|
||||||
|
|
||||||
return ret;
|
return f;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
WFile *open_existing_wfile(const char *name, uint64_t *size)
|
WFile *open_existing_wfile(const char *name, uint64_t *size)
|
||||||
{
|
{
|
||||||
int fd;
|
int fd;
|
||||||
WFile *ret;
|
WFile *f;
|
||||||
|
|
||||||
fd = open(name, O_APPEND | O_WRONLY);
|
fd = open(name, O_APPEND | O_WRONLY);
|
||||||
if (fd < 0)
|
if (fd < 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
ret = snew(WFile);
|
f = snew(WFile);
|
||||||
ret->fd = fd;
|
f->fd = fd;
|
||||||
ret->name = dupstr(name);
|
f->name = dupstr(name);
|
||||||
|
|
||||||
if (size) {
|
if (size) {
|
||||||
struct stat statbuf;
|
struct stat statbuf;
|
||||||
@ -214,7 +214,7 @@ WFile *open_existing_wfile(const char *name, uint64_t *size)
|
|||||||
*size = statbuf.st_size;
|
*size = statbuf.st_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return f;
|
||||||
}
|
}
|
||||||
|
|
||||||
int write_to_file(WFile *f, void *buffer, int length)
|
int write_to_file(WFile *f, void *buffer, int length)
|
||||||
@ -311,18 +311,15 @@ struct DirHandle {
|
|||||||
|
|
||||||
DirHandle *open_directory(const char *name, const char **errmsg)
|
DirHandle *open_directory(const char *name, const char **errmsg)
|
||||||
{
|
{
|
||||||
DIR *dir;
|
DIR *dp = opendir(name);
|
||||||
DirHandle *ret;
|
if (!dp) {
|
||||||
|
|
||||||
dir = opendir(name);
|
|
||||||
if (!dir) {
|
|
||||||
*errmsg = strerror(errno);
|
*errmsg = strerror(errno);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = snew(DirHandle);
|
DirHandle *dir = snew(DirHandle);
|
||||||
ret->dir = dir;
|
dir->dir = dp;
|
||||||
return ret;
|
return dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *read_filename(DirHandle *dir)
|
char *read_filename(DirHandle *dir)
|
||||||
@ -388,16 +385,16 @@ struct WildcardMatcher {
|
|||||||
int i;
|
int i;
|
||||||
};
|
};
|
||||||
WildcardMatcher *begin_wildcard_matching(const char *name) {
|
WildcardMatcher *begin_wildcard_matching(const char *name) {
|
||||||
WildcardMatcher *ret = snew(WildcardMatcher);
|
WildcardMatcher *dir = snew(WildcardMatcher);
|
||||||
|
|
||||||
if (glob(name, 0, NULL, &ret->globbed) < 0) {
|
if (glob(name, 0, NULL, &dir->globbed) < 0) {
|
||||||
sfree(ret);
|
sfree(dir);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret->i = 0;
|
dir->i = 0;
|
||||||
|
|
||||||
return ret;
|
return dir;
|
||||||
}
|
}
|
||||||
char *wildcard_get_filename(WildcardMatcher *dir) {
|
char *wildcard_get_filename(WildcardMatcher *dir) {
|
||||||
if (dir->i < dir->globbed.gl_pathc) {
|
if (dir->i < dir->globbed.gl_pathc) {
|
||||||
|
@ -9,9 +9,9 @@
|
|||||||
|
|
||||||
Filename *filename_from_str(const char *str)
|
Filename *filename_from_str(const char *str)
|
||||||
{
|
{
|
||||||
Filename *ret = snew(Filename);
|
Filename *fn = snew(Filename);
|
||||||
ret->path = dupstr(str);
|
fn->path = dupstr(str);
|
||||||
return ret;
|
return fn;
|
||||||
}
|
}
|
||||||
|
|
||||||
Filename *filename_copy(const Filename *fn)
|
Filename *filename_copy(const Filename *fn)
|
||||||
|
@ -63,11 +63,11 @@ struct node234_Tag {
|
|||||||
*/
|
*/
|
||||||
tree234 *newtree234(cmpfn234 cmp)
|
tree234 *newtree234(cmpfn234 cmp)
|
||||||
{
|
{
|
||||||
tree234 *ret = snew(tree234);
|
tree234 *t = snew(tree234);
|
||||||
LOG(("created tree %p\n", ret));
|
LOG(("created tree %p\n", t));
|
||||||
ret->root = NULL;
|
t->root = NULL;
|
||||||
ret->cmp = cmp;
|
t->cmp = cmp;
|
||||||
return ret;
|
return t;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -201,35 +201,35 @@ static const SocketVtable NamedPipeServerSocket_sockvt = {
|
|||||||
|
|
||||||
Socket *new_named_pipe_listener(const char *pipename, Plug *plug)
|
Socket *new_named_pipe_listener(const char *pipename, Plug *plug)
|
||||||
{
|
{
|
||||||
NamedPipeServerSocket *ret = snew(NamedPipeServerSocket);
|
NamedPipeServerSocket *ps = snew(NamedPipeServerSocket);
|
||||||
ret->sock.vt = &NamedPipeServerSocket_sockvt;
|
ps->sock.vt = &NamedPipeServerSocket_sockvt;
|
||||||
ret->plug = plug;
|
ps->plug = plug;
|
||||||
ret->error = NULL;
|
ps->error = NULL;
|
||||||
ret->psd = NULL;
|
ps->psd = NULL;
|
||||||
ret->pipename = dupstr(pipename);
|
ps->pipename = dupstr(pipename);
|
||||||
ret->acl = NULL;
|
ps->acl = NULL;
|
||||||
ret->callback_handle = NULL;
|
ps->callback_handle = NULL;
|
||||||
|
|
||||||
assert(strncmp(pipename, "\\\\.\\pipe\\", 9) == 0);
|
assert(strncmp(pipename, "\\\\.\\pipe\\", 9) == 0);
|
||||||
assert(strchr(pipename + 9, '\\') == NULL);
|
assert(strchr(pipename + 9, '\\') == NULL);
|
||||||
|
|
||||||
if (!make_private_security_descriptor(GENERIC_READ | GENERIC_WRITE,
|
if (!make_private_security_descriptor(GENERIC_READ | GENERIC_WRITE,
|
||||||
&ret->psd, &ret->acl, &ret->error)) {
|
&ps->psd, &ps->acl, &ps->error)) {
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!create_named_pipe(ret, true)) {
|
if (!create_named_pipe(ps, true)) {
|
||||||
ret->error = dupprintf("unable to create named pipe '%s': %s",
|
ps->error = dupprintf("unable to create named pipe '%s': %s",
|
||||||
pipename, win_strerror(GetLastError()));
|
pipename, win_strerror(GetLastError()));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
memset(&ret->connect_ovl, 0, sizeof(ret->connect_ovl));
|
memset(&ps->connect_ovl, 0, sizeof(ps->connect_ovl));
|
||||||
ret->connect_ovl.hEvent = CreateEvent(NULL, true, false, NULL);
|
ps->connect_ovl.hEvent = CreateEvent(NULL, true, false, NULL);
|
||||||
ret->callback_handle = add_handle_wait(
|
ps->callback_handle = add_handle_wait(
|
||||||
ret->connect_ovl.hEvent, named_pipe_connect_callback, ret);
|
ps->connect_ovl.hEvent, named_pipe_connect_callback, ps);
|
||||||
named_pipe_accept_loop(ret, false);
|
named_pipe_accept_loop(ps, false);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
return &ret->sock;
|
return &ps->sock;
|
||||||
}
|
}
|
||||||
|
@ -547,18 +547,18 @@ SockAddr *sk_namelookup(const char *host, char **canonicalname,
|
|||||||
|
|
||||||
static SockAddr *sk_special_addr(SuperFamily superfamily, const char *name)
|
static SockAddr *sk_special_addr(SuperFamily superfamily, const char *name)
|
||||||
{
|
{
|
||||||
SockAddr *ret = snew(SockAddr);
|
SockAddr *addr = snew(SockAddr);
|
||||||
ret->error = NULL;
|
addr->error = NULL;
|
||||||
ret->superfamily = superfamily;
|
addr->superfamily = superfamily;
|
||||||
#ifndef NO_IPV6
|
#ifndef NO_IPV6
|
||||||
ret->ais = NULL;
|
addr->ais = NULL;
|
||||||
#endif
|
#endif
|
||||||
ret->addresses = NULL;
|
addr->addresses = NULL;
|
||||||
ret->naddresses = 0;
|
addr->naddresses = 0;
|
||||||
ret->refcount = 1;
|
addr->refcount = 1;
|
||||||
strncpy(ret->hostname, name, lenof(ret->hostname));
|
strncpy(addr->hostname, name, lenof(addr->hostname));
|
||||||
ret->hostname[lenof(ret->hostname)-1] = '\0';
|
addr->hostname[lenof(addr->hostname)-1] = '\0';
|
||||||
return ret;
|
return addr;
|
||||||
}
|
}
|
||||||
|
|
||||||
SockAddr *sk_nonamelookup(const char *host)
|
SockAddr *sk_nonamelookup(const char *host)
|
||||||
@ -838,47 +838,47 @@ static Socket *sk_net_accept(accept_ctx_t ctx, Plug *plug)
|
|||||||
{
|
{
|
||||||
DWORD err;
|
DWORD err;
|
||||||
const char *errstr;
|
const char *errstr;
|
||||||
NetSocket *ret;
|
NetSocket *s;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create NetSocket structure.
|
* Create NetSocket structure.
|
||||||
*/
|
*/
|
||||||
ret = snew(NetSocket);
|
s = snew(NetSocket);
|
||||||
ret->sock.vt = &NetSocket_sockvt;
|
s->sock.vt = &NetSocket_sockvt;
|
||||||
ret->error = NULL;
|
s->error = NULL;
|
||||||
ret->plug = plug;
|
s->plug = plug;
|
||||||
bufchain_init(&ret->output_data);
|
bufchain_init(&s->output_data);
|
||||||
ret->writable = true; /* to start with */
|
s->writable = true; /* to start with */
|
||||||
ret->sending_oob = 0;
|
s->sending_oob = 0;
|
||||||
ret->outgoingeof = EOF_NO;
|
s->outgoingeof = EOF_NO;
|
||||||
ret->frozen = true;
|
s->frozen = true;
|
||||||
ret->frozen_readable = false;
|
s->frozen_readable = false;
|
||||||
ret->localhost_only = false; /* unused, but best init anyway */
|
s->localhost_only = false; /* unused, but best init anyway */
|
||||||
ret->pending_error = 0;
|
s->pending_error = 0;
|
||||||
ret->parent = ret->child = NULL;
|
s->parent = s->child = NULL;
|
||||||
ret->addr = NULL;
|
s->addr = NULL;
|
||||||
|
|
||||||
ret->s = (SOCKET)ctx.p;
|
s->s = (SOCKET)ctx.p;
|
||||||
|
|
||||||
if (ret->s == INVALID_SOCKET) {
|
if (s->s == INVALID_SOCKET) {
|
||||||
err = p_WSAGetLastError();
|
err = p_WSAGetLastError();
|
||||||
ret->error = winsock_error_string(err);
|
s->error = winsock_error_string(err);
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret->oobinline = false;
|
s->oobinline = false;
|
||||||
|
|
||||||
/* Set up a select mechanism. This could be an AsyncSelect on a
|
/* Set up a select mechanism. This could be an AsyncSelect on a
|
||||||
* window, or an EventSelect on an event object. */
|
* window, or an EventSelect on an event object. */
|
||||||
errstr = do_select(ret->s, true);
|
errstr = do_select(s->s, true);
|
||||||
if (errstr) {
|
if (errstr) {
|
||||||
ret->error = errstr;
|
s->error = errstr;
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
add234(sktree, ret);
|
add234(sktree, s);
|
||||||
|
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
static DWORD try_connect(NetSocket *sock)
|
static DWORD try_connect(NetSocket *sock)
|
||||||
@ -1087,48 +1087,48 @@ static DWORD try_connect(NetSocket *sock)
|
|||||||
Socket *sk_new(SockAddr *addr, int port, bool privport, bool oobinline,
|
Socket *sk_new(SockAddr *addr, int port, bool privport, bool oobinline,
|
||||||
bool nodelay, bool keepalive, Plug *plug)
|
bool nodelay, bool keepalive, Plug *plug)
|
||||||
{
|
{
|
||||||
NetSocket *ret;
|
NetSocket *s;
|
||||||
DWORD err;
|
DWORD err;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create NetSocket structure.
|
* Create NetSocket structure.
|
||||||
*/
|
*/
|
||||||
ret = snew(NetSocket);
|
s = snew(NetSocket);
|
||||||
ret->sock.vt = &NetSocket_sockvt;
|
s->sock.vt = &NetSocket_sockvt;
|
||||||
ret->error = NULL;
|
s->error = NULL;
|
||||||
ret->plug = plug;
|
s->plug = plug;
|
||||||
bufchain_init(&ret->output_data);
|
bufchain_init(&s->output_data);
|
||||||
ret->connected = false; /* to start with */
|
s->connected = false; /* to start with */
|
||||||
ret->writable = false; /* to start with */
|
s->writable = false; /* to start with */
|
||||||
ret->sending_oob = 0;
|
s->sending_oob = 0;
|
||||||
ret->outgoingeof = EOF_NO;
|
s->outgoingeof = EOF_NO;
|
||||||
ret->frozen = false;
|
s->frozen = false;
|
||||||
ret->frozen_readable = false;
|
s->frozen_readable = false;
|
||||||
ret->localhost_only = false; /* unused, but best init anyway */
|
s->localhost_only = false; /* unused, but best init anyway */
|
||||||
ret->pending_error = 0;
|
s->pending_error = 0;
|
||||||
ret->parent = ret->child = NULL;
|
s->parent = s->child = NULL;
|
||||||
ret->oobinline = oobinline;
|
s->oobinline = oobinline;
|
||||||
ret->nodelay = nodelay;
|
s->nodelay = nodelay;
|
||||||
ret->keepalive = keepalive;
|
s->keepalive = keepalive;
|
||||||
ret->privport = privport;
|
s->privport = privport;
|
||||||
ret->port = port;
|
s->port = port;
|
||||||
ret->addr = addr;
|
s->addr = addr;
|
||||||
START_STEP(ret->addr, ret->step);
|
START_STEP(s->addr, s->step);
|
||||||
ret->s = INVALID_SOCKET;
|
s->s = INVALID_SOCKET;
|
||||||
|
|
||||||
err = 0;
|
err = 0;
|
||||||
do {
|
do {
|
||||||
err = try_connect(ret);
|
err = try_connect(s);
|
||||||
} while (err && sk_nextaddr(ret->addr, &ret->step));
|
} while (err && sk_nextaddr(s->addr, &s->step));
|
||||||
|
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
static Socket *sk_newlistener_internal(
|
static Socket *sk_newlistener_internal(
|
||||||
const char *srcaddr, int port, Plug *plug,
|
const char *srcaddr, int port, Plug *plug,
|
||||||
bool local_host_only, int orig_address_family)
|
bool local_host_only, int orig_address_family)
|
||||||
{
|
{
|
||||||
SOCKET s;
|
SOCKET sk;
|
||||||
SOCKADDR_IN a;
|
SOCKADDR_IN a;
|
||||||
#ifndef NO_IPV6
|
#ifndef NO_IPV6
|
||||||
SOCKADDR_IN6 a6;
|
SOCKADDR_IN6 a6;
|
||||||
@ -1141,7 +1141,7 @@ static Socket *sk_newlistener_internal(
|
|||||||
|
|
||||||
DWORD err;
|
DWORD err;
|
||||||
const char *errstr;
|
const char *errstr;
|
||||||
NetSocket *ret;
|
NetSocket *s;
|
||||||
int retcode;
|
int retcode;
|
||||||
|
|
||||||
int address_family = orig_address_family;
|
int address_family = orig_address_family;
|
||||||
@ -1149,20 +1149,20 @@ static Socket *sk_newlistener_internal(
|
|||||||
/*
|
/*
|
||||||
* Create NetSocket structure.
|
* Create NetSocket structure.
|
||||||
*/
|
*/
|
||||||
ret = snew(NetSocket);
|
s = snew(NetSocket);
|
||||||
ret->sock.vt = &NetSocket_sockvt;
|
s->sock.vt = &NetSocket_sockvt;
|
||||||
ret->error = NULL;
|
s->error = NULL;
|
||||||
ret->plug = plug;
|
s->plug = plug;
|
||||||
bufchain_init(&ret->output_data);
|
bufchain_init(&s->output_data);
|
||||||
ret->writable = false; /* to start with */
|
s->writable = false; /* to start with */
|
||||||
ret->sending_oob = 0;
|
s->sending_oob = 0;
|
||||||
ret->outgoingeof = EOF_NO;
|
s->outgoingeof = EOF_NO;
|
||||||
ret->frozen = false;
|
s->frozen = false;
|
||||||
ret->frozen_readable = false;
|
s->frozen_readable = false;
|
||||||
ret->localhost_only = local_host_only;
|
s->localhost_only = local_host_only;
|
||||||
ret->pending_error = 0;
|
s->pending_error = 0;
|
||||||
ret->parent = ret->child = NULL;
|
s->parent = s->child = NULL;
|
||||||
ret->addr = NULL;
|
s->addr = NULL;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Our default, if passed the `don't care' value
|
* Our default, if passed the `don't care' value
|
||||||
@ -1176,25 +1176,25 @@ static Socket *sk_newlistener_internal(
|
|||||||
/*
|
/*
|
||||||
* Open socket.
|
* Open socket.
|
||||||
*/
|
*/
|
||||||
s = p_socket(address_family, SOCK_STREAM, 0);
|
sk = p_socket(address_family, SOCK_STREAM, 0);
|
||||||
ret->s = s;
|
s->s = sk;
|
||||||
|
|
||||||
if (s == INVALID_SOCKET) {
|
if (sk == INVALID_SOCKET) {
|
||||||
err = p_WSAGetLastError();
|
err = p_WSAGetLastError();
|
||||||
ret->error = winsock_error_string(err);
|
s->error = winsock_error_string(err);
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
SetHandleInformation((HANDLE)s, HANDLE_FLAG_INHERIT, 0);
|
SetHandleInformation((HANDLE)sk, HANDLE_FLAG_INHERIT, 0);
|
||||||
|
|
||||||
ret->oobinline = false;
|
s->oobinline = false;
|
||||||
|
|
||||||
#if HAVE_AFUNIX_H
|
#if HAVE_AFUNIX_H
|
||||||
if (address_family != AF_UNIX)
|
if (address_family != AF_UNIX)
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
BOOL on = true;
|
BOOL on = true;
|
||||||
p_setsockopt(s, SOL_SOCKET, SO_EXCLUSIVEADDRUSE,
|
p_setsockopt(sk, SOL_SOCKET, SO_EXCLUSIVEADDRUSE,
|
||||||
(const char *)&on, sizeof(on));
|
(const char *)&on, sizeof(on));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1244,7 +1244,7 @@ static Socket *sk_newlistener_internal(
|
|||||||
a.sin_addr.s_addr = p_inet_addr(srcaddr);
|
a.sin_addr.s_addr = p_inet_addr(srcaddr);
|
||||||
if (a.sin_addr.s_addr != INADDR_NONE) {
|
if (a.sin_addr.s_addr != INADDR_NONE) {
|
||||||
/* Override localhost_only with specified listen addr. */
|
/* Override localhost_only with specified listen addr. */
|
||||||
ret->localhost_only = ipv4_is_loopback(a.sin_addr);
|
s->localhost_only = ipv4_is_loopback(a.sin_addr);
|
||||||
got_addr = true;
|
got_addr = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1277,7 +1277,7 @@ static Socket *sk_newlistener_internal(
|
|||||||
unreachable("bad address family in sk_newlistener_internal");
|
unreachable("bad address family in sk_newlistener_internal");
|
||||||
}
|
}
|
||||||
|
|
||||||
retcode = p_bind(s, bindaddr, bindsize);
|
retcode = p_bind(sk, bindaddr, bindsize);
|
||||||
if (retcode != SOCKET_ERROR) {
|
if (retcode != SOCKET_ERROR) {
|
||||||
err = 0;
|
err = 0;
|
||||||
} else {
|
} else {
|
||||||
@ -1285,28 +1285,28 @@ static Socket *sk_newlistener_internal(
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (err) {
|
if (err) {
|
||||||
p_closesocket(s);
|
p_closesocket(sk);
|
||||||
ret->error = winsock_error_string(err);
|
s->error = winsock_error_string(err);
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (p_listen(s, SOMAXCONN) == SOCKET_ERROR) {
|
if (p_listen(sk, SOMAXCONN) == SOCKET_ERROR) {
|
||||||
p_closesocket(s);
|
p_closesocket(sk);
|
||||||
ret->error = winsock_error_string(p_WSAGetLastError());
|
s->error = winsock_error_string(p_WSAGetLastError());
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set up a select mechanism. This could be an AsyncSelect on a
|
/* Set up a select mechanism. This could be an AsyncSelect on a
|
||||||
* window, or an EventSelect on an event object. */
|
* window, or an EventSelect on an event object. */
|
||||||
errstr = do_select(s, true);
|
errstr = do_select(sk, true);
|
||||||
if (errstr) {
|
if (errstr) {
|
||||||
p_closesocket(s);
|
p_closesocket(sk);
|
||||||
ret->error = errstr;
|
s->error = errstr;
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
add234(sktree, ret);
|
add234(sktree, s);
|
||||||
|
|
||||||
#ifndef NO_IPV6
|
#ifndef NO_IPV6
|
||||||
/*
|
/*
|
||||||
@ -1320,8 +1320,8 @@ static Socket *sk_newlistener_internal(
|
|||||||
if (other) {
|
if (other) {
|
||||||
NetSocket *ns = container_of(other, NetSocket, sock);
|
NetSocket *ns = container_of(other, NetSocket, sock);
|
||||||
if (!ns->error) {
|
if (!ns->error) {
|
||||||
ns->parent = ret;
|
ns->parent = s;
|
||||||
ret->child = ns;
|
s->child = ns;
|
||||||
} else {
|
} else {
|
||||||
sfree(ns);
|
sfree(ns);
|
||||||
}
|
}
|
||||||
@ -1329,7 +1329,7 @@ static Socket *sk_newlistener_internal(
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return &ret->sock;
|
return &s->sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
|
Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
|
||||||
@ -1871,9 +1871,9 @@ char *get_hostname(void)
|
|||||||
|
|
||||||
SockAddr *platform_get_x11_unix_address(const char *display, int displaynum)
|
SockAddr *platform_get_x11_unix_address(const char *display, int displaynum)
|
||||||
{
|
{
|
||||||
SockAddr *ret = snew(SockAddr);
|
SockAddr *addr = snew(SockAddr);
|
||||||
memset(ret, 0, sizeof(SockAddr));
|
memset(addr, 0, sizeof(SockAddr));
|
||||||
ret->error = "unix sockets for X11 not supported on this platform";
|
addr->error = "unix sockets for X11 not supported on this platform";
|
||||||
ret->refcount = 1;
|
addr->refcount = 1;
|
||||||
return ret;
|
return addr;
|
||||||
}
|
}
|
||||||
|
@ -93,7 +93,7 @@ static bool printer_add_enum(int param, DWORD level, char **buffer,
|
|||||||
|
|
||||||
printer_enum *printer_start_enum(int *nprinters_ptr)
|
printer_enum *printer_start_enum(int *nprinters_ptr)
|
||||||
{
|
{
|
||||||
printer_enum *ret = snew(printer_enum);
|
printer_enum *pe = snew(printer_enum);
|
||||||
char *buffer = NULL;
|
char *buffer = NULL;
|
||||||
|
|
||||||
*nprinters_ptr = 0; /* default return value */
|
*nprinters_ptr = 0; /* default return value */
|
||||||
@ -110,30 +110,30 @@ printer_enum *printer_start_enum(int *nprinters_ptr)
|
|||||||
* Bletch.
|
* Bletch.
|
||||||
*/
|
*/
|
||||||
if (osPlatformId != VER_PLATFORM_WIN32_NT) {
|
if (osPlatformId != VER_PLATFORM_WIN32_NT) {
|
||||||
ret->enum_level = 5;
|
pe->enum_level = 5;
|
||||||
} else {
|
} else {
|
||||||
ret->enum_level = 4;
|
pe->enum_level = 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!printer_add_enum(PRINTER_ENUM_LOCAL | PRINTER_ENUM_CONNECTIONS,
|
if (!printer_add_enum(PRINTER_ENUM_LOCAL | PRINTER_ENUM_CONNECTIONS,
|
||||||
ret->enum_level, &buffer, 0, nprinters_ptr))
|
pe->enum_level, &buffer, 0, nprinters_ptr))
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
switch (ret->enum_level) {
|
switch (pe->enum_level) {
|
||||||
case 4:
|
case 4:
|
||||||
ret->info.i4 = (LPPRINTER_INFO_4)buffer;
|
pe->info.i4 = (LPPRINTER_INFO_4)buffer;
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
ret->info.i5 = (LPPRINTER_INFO_5)buffer;
|
pe->info.i5 = (LPPRINTER_INFO_5)buffer;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
ret->nprinters = *nprinters_ptr;
|
pe->nprinters = *nprinters_ptr;
|
||||||
|
|
||||||
return ret;
|
return pe;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
sfree(buffer);
|
sfree(buffer);
|
||||||
sfree(ret);
|
sfree(pe);
|
||||||
*nprinters_ptr = 0;
|
*nprinters_ptr = 0;
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@ -171,38 +171,38 @@ void printer_finish_enum(printer_enum *pe)
|
|||||||
|
|
||||||
printer_job *printer_start_job(char *printer)
|
printer_job *printer_start_job(char *printer)
|
||||||
{
|
{
|
||||||
printer_job *ret = snew(printer_job);
|
printer_job *pj = snew(printer_job);
|
||||||
DOC_INFO_1 docinfo;
|
DOC_INFO_1 docinfo;
|
||||||
bool jobstarted = false, pagestarted = false;
|
bool jobstarted = false, pagestarted = false;
|
||||||
|
|
||||||
init_winfuncs();
|
init_winfuncs();
|
||||||
|
|
||||||
ret->hprinter = NULL;
|
pj->hprinter = NULL;
|
||||||
if (!p_OpenPrinter(printer, &ret->hprinter, NULL))
|
if (!p_OpenPrinter(printer, &pj->hprinter, NULL))
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
docinfo.pDocName = "PuTTY remote printer output";
|
docinfo.pDocName = "PuTTY remote printer output";
|
||||||
docinfo.pOutputFile = NULL;
|
docinfo.pOutputFile = NULL;
|
||||||
docinfo.pDatatype = "RAW";
|
docinfo.pDatatype = "RAW";
|
||||||
|
|
||||||
if (!p_StartDocPrinter(ret->hprinter, 1, (LPBYTE)&docinfo))
|
if (!p_StartDocPrinter(pj->hprinter, 1, (LPBYTE)&docinfo))
|
||||||
goto error;
|
goto error;
|
||||||
jobstarted = true;
|
jobstarted = true;
|
||||||
|
|
||||||
if (!p_StartPagePrinter(ret->hprinter))
|
if (!p_StartPagePrinter(pj->hprinter))
|
||||||
goto error;
|
goto error;
|
||||||
pagestarted = true;
|
pagestarted = true;
|
||||||
|
|
||||||
return ret;
|
return pj;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
if (pagestarted)
|
if (pagestarted)
|
||||||
p_EndPagePrinter(ret->hprinter);
|
p_EndPagePrinter(pj->hprinter);
|
||||||
if (jobstarted)
|
if (jobstarted)
|
||||||
p_EndDocPrinter(ret->hprinter);
|
p_EndDocPrinter(pj->hprinter);
|
||||||
if (ret->hprinter)
|
if (pj->hprinter)
|
||||||
p_ClosePrinter(ret->hprinter);
|
p_ClosePrinter(pj->hprinter);
|
||||||
sfree(ret);
|
sfree(pj);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -104,15 +104,15 @@ RFile *open_existing_file(const char *name, uint64_t *size,
|
|||||||
long *perms)
|
long *perms)
|
||||||
{
|
{
|
||||||
HANDLE h;
|
HANDLE h;
|
||||||
RFile *ret;
|
RFile *f;
|
||||||
|
|
||||||
h = CreateFile(name, GENERIC_READ, FILE_SHARE_READ, NULL,
|
h = CreateFile(name, GENERIC_READ, FILE_SHARE_READ, NULL,
|
||||||
OPEN_EXISTING, 0, 0);
|
OPEN_EXISTING, 0, 0);
|
||||||
if (h == INVALID_HANDLE_VALUE)
|
if (h == INVALID_HANDLE_VALUE)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
ret = snew(RFile);
|
f = snew(RFile);
|
||||||
ret->h = h;
|
f->h = h;
|
||||||
|
|
||||||
if (size) {
|
if (size) {
|
||||||
DWORD lo, hi;
|
DWORD lo, hi;
|
||||||
@ -132,7 +132,7 @@ RFile *open_existing_file(const char *name, uint64_t *size,
|
|||||||
if (perms)
|
if (perms)
|
||||||
*perms = -1;
|
*perms = -1;
|
||||||
|
|
||||||
return ret;
|
return f;
|
||||||
}
|
}
|
||||||
|
|
||||||
int read_from_file(RFile *f, void *buffer, int length)
|
int read_from_file(RFile *f, void *buffer, int length)
|
||||||
@ -157,31 +157,31 @@ struct WFile {
|
|||||||
WFile *open_new_file(const char *name, long perms)
|
WFile *open_new_file(const char *name, long perms)
|
||||||
{
|
{
|
||||||
HANDLE h;
|
HANDLE h;
|
||||||
WFile *ret;
|
WFile *f;
|
||||||
|
|
||||||
h = CreateFile(name, GENERIC_WRITE, 0, NULL,
|
h = CreateFile(name, GENERIC_WRITE, 0, NULL,
|
||||||
CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0);
|
CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0);
|
||||||
if (h == INVALID_HANDLE_VALUE)
|
if (h == INVALID_HANDLE_VALUE)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
ret = snew(WFile);
|
f = snew(WFile);
|
||||||
ret->h = h;
|
f->h = h;
|
||||||
|
|
||||||
return ret;
|
return f;
|
||||||
}
|
}
|
||||||
|
|
||||||
WFile *open_existing_wfile(const char *name, uint64_t *size)
|
WFile *open_existing_wfile(const char *name, uint64_t *size)
|
||||||
{
|
{
|
||||||
HANDLE h;
|
HANDLE h;
|
||||||
WFile *ret;
|
WFile *f;
|
||||||
|
|
||||||
h = CreateFile(name, GENERIC_WRITE, FILE_SHARE_READ, NULL,
|
h = CreateFile(name, GENERIC_WRITE, FILE_SHARE_READ, NULL,
|
||||||
OPEN_EXISTING, 0, 0);
|
OPEN_EXISTING, 0, 0);
|
||||||
if (h == INVALID_HANDLE_VALUE)
|
if (h == INVALID_HANDLE_VALUE)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
ret = snew(WFile);
|
f = snew(WFile);
|
||||||
ret->h = h;
|
f->h = h;
|
||||||
|
|
||||||
if (size) {
|
if (size) {
|
||||||
DWORD lo, hi;
|
DWORD lo, hi;
|
||||||
@ -189,7 +189,7 @@ WFile *open_existing_wfile(const char *name, uint64_t *size)
|
|||||||
*size = uint64_from_words(hi, lo);
|
*size = uint64_from_words(hi, lo);
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return f;
|
||||||
}
|
}
|
||||||
|
|
||||||
int write_to_file(WFile *f, void *buffer, int length)
|
int write_to_file(WFile *f, void *buffer, int length)
|
||||||
@ -277,7 +277,7 @@ DirHandle *open_directory(const char *name, const char **errmsg)
|
|||||||
HANDLE h;
|
HANDLE h;
|
||||||
WIN32_FIND_DATA fdat;
|
WIN32_FIND_DATA fdat;
|
||||||
char *findfile;
|
char *findfile;
|
||||||
DirHandle *ret;
|
DirHandle *dir;
|
||||||
|
|
||||||
/* Enumerate files in dir `foo'. */
|
/* Enumerate files in dir `foo'. */
|
||||||
findfile = dupcat(name, "/*");
|
findfile = dupcat(name, "/*");
|
||||||
@ -288,10 +288,10 @@ DirHandle *open_directory(const char *name, const char **errmsg)
|
|||||||
}
|
}
|
||||||
sfree(findfile);
|
sfree(findfile);
|
||||||
|
|
||||||
ret = snew(DirHandle);
|
dir = snew(DirHandle);
|
||||||
ret->h = h;
|
dir->h = h;
|
||||||
ret->name = dupstr(fdat.cFileName);
|
dir->name = dupstr(fdat.cFileName);
|
||||||
return ret;
|
return dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *read_filename(DirHandle *dir)
|
char *read_filename(DirHandle *dir)
|
||||||
@ -384,26 +384,26 @@ WildcardMatcher *begin_wildcard_matching(const char *name)
|
|||||||
{
|
{
|
||||||
HANDLE h;
|
HANDLE h;
|
||||||
WIN32_FIND_DATA fdat;
|
WIN32_FIND_DATA fdat;
|
||||||
WildcardMatcher *ret;
|
WildcardMatcher *dir;
|
||||||
char *last;
|
char *last;
|
||||||
|
|
||||||
h = FindFirstFile(name, &fdat);
|
h = FindFirstFile(name, &fdat);
|
||||||
if (h == INVALID_HANDLE_VALUE)
|
if (h == INVALID_HANDLE_VALUE)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
ret = snew(WildcardMatcher);
|
dir = snew(WildcardMatcher);
|
||||||
ret->h = h;
|
dir->h = h;
|
||||||
ret->srcpath = dupstr(name);
|
dir->srcpath = dupstr(name);
|
||||||
last = stripslashes(ret->srcpath, true);
|
last = stripslashes(dir->srcpath, true);
|
||||||
*last = '\0';
|
*last = '\0';
|
||||||
if (fdat.cFileName[0] == '.' &&
|
if (fdat.cFileName[0] == '.' &&
|
||||||
(fdat.cFileName[1] == '\0' ||
|
(fdat.cFileName[1] == '\0' ||
|
||||||
(fdat.cFileName[1] == '.' && fdat.cFileName[2] == '\0')))
|
(fdat.cFileName[1] == '.' && fdat.cFileName[2] == '\0')))
|
||||||
ret->name = NULL;
|
dir->name = NULL;
|
||||||
else
|
else
|
||||||
ret->name = dupcat(ret->srcpath, fdat.cFileName);
|
dir->name = dupcat(dir->srcpath, fdat.cFileName);
|
||||||
|
|
||||||
return ret;
|
return dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *wildcard_get_filename(WildcardMatcher *dir)
|
char *wildcard_get_filename(WildcardMatcher *dir)
|
||||||
|
@ -51,9 +51,9 @@ settings_w *open_settings_w(const char *sessionname, char **errmsg)
|
|||||||
}
|
}
|
||||||
strbuf_free(sb);
|
strbuf_free(sb);
|
||||||
|
|
||||||
settings_w *toret = snew(settings_w);
|
settings_w *handle = snew(settings_w);
|
||||||
toret->sesskey = sesskey;
|
handle->sesskey = sesskey;
|
||||||
return toret;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
void write_setting_s(settings_w *handle, const char *key, const char *value)
|
void write_setting_s(settings_w *handle, const char *key, const char *value)
|
||||||
@ -91,9 +91,9 @@ settings_r *open_settings_r(const char *sessionname)
|
|||||||
if (!sesskey)
|
if (!sesskey)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
settings_r *toret = snew(settings_r);
|
settings_r *handle = snew(settings_r);
|
||||||
toret->sesskey = sesskey;
|
handle->sesskey = sesskey;
|
||||||
return toret;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *read_setting_s(settings_r *handle, const char *key)
|
char *read_setting_s(settings_r *handle, const char *key)
|
||||||
@ -221,13 +221,13 @@ settings_e *enum_settings_start(void)
|
|||||||
if (!key)
|
if (!key)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
settings_e *ret = snew(settings_e);
|
settings_e *e = snew(settings_e);
|
||||||
if (ret) {
|
if (e) {
|
||||||
ret->key = key;
|
e->key = key;
|
||||||
ret->i = 0;
|
e->i = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return e;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool enum_settings_next(settings_e *e, strbuf *sb)
|
bool enum_settings_next(settings_e *e, strbuf *sb)
|
||||||
|
@ -6,9 +6,9 @@
|
|||||||
|
|
||||||
Filename *filename_from_str(const char *str)
|
Filename *filename_from_str(const char *str)
|
||||||
{
|
{
|
||||||
Filename *ret = snew(Filename);
|
Filename *fn = snew(Filename);
|
||||||
ret->path = dupstr(str);
|
fn->path = dupstr(str);
|
||||||
return ret;
|
return fn;
|
||||||
}
|
}
|
||||||
|
|
||||||
Filename *filename_copy(const Filename *fn)
|
Filename *filename_copy(const Filename *fn)
|
||||||
|
@ -60,9 +60,9 @@ bool request_file(filereq *state, OPENFILENAME *of, bool preserve, bool save)
|
|||||||
|
|
||||||
filereq *filereq_new(void)
|
filereq *filereq_new(void)
|
||||||
{
|
{
|
||||||
filereq *ret = snew(filereq);
|
filereq *state = snew(filereq);
|
||||||
ret->cwd[0] = '\0';
|
state->cwd[0] = '\0';
|
||||||
return ret;
|
return state;
|
||||||
}
|
}
|
||||||
|
|
||||||
void filereq_free(filereq *state)
|
void filereq_free(filereq *state)
|
||||||
|
Loading…
Reference in New Issue
Block a user