summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorChris Young <chris@unsatisfactorysoftware.co.uk>2012-06-14 18:57:24 +0100
committerChris Young <chris@unsatisfactorysoftware.co.uk>2012-06-14 18:57:24 +0100
commita8df98c6fb07b8ddff18a01d7f2f607d9493dd7c (patch)
tree508aa2bdd6278e967ce4122c37a6a7d9a77bdad5 /src
parenta21bb1aa33e9887c06852db62526895df6091736 (diff)
downloadlibgit2-a8df98c6fb07b8ddff18a01d7f2f607d9493dd7c.tar.gz
Updates from comments on OS4 compatibility pull request http://github.com/libgit2/libgit2/pull/766
Diffstat (limited to 'src')
-rwxr-xr-xsrc/amiga/map.c3
-rw-r--r--src/netops.c45
-rw-r--r--src/path.c9
-rw-r--r--src/pool.c2
-rw-r--r--src/posix.h7
5 files changed, 35 insertions, 31 deletions
diff --git a/src/amiga/map.c b/src/amiga/map.c
index d36bcbc9..643e6c65 100755
--- a/src/amiga/map.c
+++ b/src/amiga/map.c
@@ -23,7 +23,8 @@ int p_mmap(git_map *out, size_t len, int prot, int flags, int fd, git_off_t offs
out->len = 0;
if ((prot & GIT_PROT_WRITE) && ((flags & GIT_MAP_TYPE) == GIT_MAP_SHARED)) {
- printf("Trying to map shared-writeable file!!!\n");
+ giterr_set(GITERR_OS, "Trying to map shared-writeable");
+ return -1;
}
if(out->data = malloc(len)) {
diff --git a/src/netops.c b/src/netops.c
index 11295c5c..166c9716 100644
--- a/src/netops.c
+++ b/src/netops.c
@@ -33,6 +33,16 @@
#include "buffer.h"
#include "transport.h"
+#ifdef NO_ADDRINFO
+struct addrinfo {
+ struct hostent *ai_hostent;
+ struct servent *ai_servent;
+ struct sockaddr_in ai_addr;
+ int ai_socktype;
+ long ai_port;
+};
+#endif
+
#ifdef GIT_WIN32
static void net_set_error(const char *str)
{
@@ -378,41 +388,38 @@ int gitno_connect(git_transport *t, const char *host, const char *port)
{
#ifndef NO_ADDRINFO
struct addrinfo *info = NULL, *p;
- struct addrinfo hints;
#else
int p;
- struct hostent *hent;
- struct servent *sent;
- struct sockaddr_in saddr;
- long port_num = 0;
#endif
+ struct addrinfo hints;
int ret;
GIT_SOCKET s = INVALID_SOCKET;
-#ifndef NO_ADDRINFO
+
memset(&hints, 0x0, sizeof(struct addrinfo));
- hints.ai_family = AF_UNSPEC;
hints.ai_socktype = SOCK_STREAM;
+#ifndef NO_ADDRINFO
+ hints.ai_family = AF_UNSPEC;
if ((ret = getaddrinfo(host, port, &hints, &info)) < 0) {
giterr_set(GITERR_NET, "Failed to resolve address for %s: %s", host, gai_strerror(ret));
return -1;
}
#else
- hent = gethostbyname(host);
- sent = getservbyname(port, 0);
+ hints.ai_hostent = gethostbyname(host);
+ hints.ai_servent = getservbyname(port, 0);
- if(sent)
- port_num = sent->s_port;
+ if(hints.ai_servent)
+ hints.ai_port = hints.ai_servent->s_port;
else
- port_num = atol(port);
+ hints.ai_port = atol(port);
#endif
#ifndef NO_ADDRINFO
for (p = info; p != NULL; p = p->ai_next) {
s = socket(p->ai_family, p->ai_socktype, p->ai_protocol);
#else
- for (p = 0; hent->h_addr_list[p] != NULL; p++) {
- s = socket(hent->h_addrtype, SOCK_STREAM, 0);
+ for (p = 0; hints.ai_hostent->h_addr_list[p] != NULL; p++) {
+ s = socket(hints.ai_hostent->h_addrtype, hints.ai_socktype, 0);
#endif
if (s == INVALID_SOCKET) {
net_set_error("error creating socket");
@@ -421,10 +428,10 @@ int gitno_connect(git_transport *t, const char *host, const char *port)
#ifndef NO_ADDRINFO
if (connect(s, p->ai_addr, (socklen_t)p->ai_addrlen) == 0)
#else
- memcpy(&saddr.sin_addr, hent->h_addr_list[p], hent->h_length);
- saddr.sin_family = hent->h_addrtype;
- saddr.sin_port = port_num;
- if (connect(s, (struct sockaddr *)&saddr, sizeof(struct sockaddr_in)) == 0)
+ memcpy(&hints.ai_addr.sin_addr, hints.ai_hostent->h_addr_list[p], hints.ai_hostent->h_length);
+ hints.ai_addr.sin_family = hints.ai_hostent->h_addrtype;
+ hints.ai_addr.sin_port = honts.ai_port;
+ if (connect(s, (struct sockaddr *)&hints.ai_addr, sizeof(struct sockaddr_in)) == 0)
#endif
break;
@@ -438,7 +445,7 @@ int gitno_connect(git_transport *t, const char *host, const char *port)
#ifndef NO_ADDRINFO
p == NULL) {
#else
- hent->h_addr_list[p] == NULL) {
+ hints.ai_hostent->h_addr_list[p] == NULL) {
#endif
giterr_set(GITERR_OS, "Failed to connect to %s", host);
return -1;
diff --git a/src/path.c b/src/path.c
index d48435bd..bd659f81 100644
--- a/src/path.c
+++ b/src/path.c
@@ -486,14 +486,9 @@ int git_path_cmp(
/* Taken from git.git */
GIT_INLINE(int) is_dot_or_dotdot(const char *name)
{
-#ifdef __amigaos4__
- /* This is irrelevant on AmigaOS */
- return 0;
-#else
return (name[0] == '.' &&
(name[1] == '\0' ||
(name[1] == '.' && name[2] == '\0')));
-#endif
}
int git_path_direach(
@@ -521,11 +516,7 @@ int git_path_direach(
de_buf = git__malloc(sizeof(struct dirent));
#endif
-#ifdef NO_READDIR_R
- while (de = readdir(dir)) {
-#else
while (p_readdir_r(dir, de_buf, de) == 0 && de != NULL) {
-#endif
int result;
if (is_dot_or_dotdot(de->d_name))
diff --git a/src/pool.c b/src/pool.c
index c5414b3b..63bf09ce 100644
--- a/src/pool.c
+++ b/src/pool.c
@@ -276,7 +276,7 @@ uint32_t git_pool__system_page_size(void)
GetSystemInfo(&info);
size = (uint32_t)info.dwPageSize;
#elif defined(__amigaos4__)
- size = (uint32_t)1000000; // random value
+ size = (uint32_t)4096; /* 4K as there is no global value we can query */
#else
size = (uint32_t)sysconf(_SC_PAGE_SIZE);
#endif
diff --git a/src/posix.h b/src/posix.h
index 6b6c53db..cc35c52e 100644
--- a/src/posix.h
+++ b/src/posix.h
@@ -86,7 +86,12 @@ extern int p_gettimeofday(struct timeval *tv, struct timezone *tz);
#ifndef NO_READDIR_R
#define p_readdir_r(d,e,r) readdir_r(d,e,&r)
#else
-#define p_readdir_r(d,e,r) r = readdir(d)
+GIT_INLINE(int) p_readdir_r(DIR *dirp, struct dirent *entry, struct direct **result)
+{
+ GIT_UNUSED(entry);
+ *result = readdir(dirp);
+ return 0;
+}
#endif
#endif