diff options
author | oskar <[email protected]> | 2024-05-22 20:11:10 +0200 |
---|---|---|
committer | oskar <[email protected]> | 2024-05-22 20:11:10 +0200 |
commit | 330c22b13e46f3ba51d5c2775235da2276dca8a0 (patch) | |
tree | e960aa230ed1ecfd9f144e9aae0b16c353443f78 /binding.c |
networking learning
Diffstat (limited to 'binding.c')
-rw-r--r-- | binding.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/binding.c b/binding.c new file mode 100644 index 0000000..ebc503d --- /dev/null +++ b/binding.c @@ -0,0 +1,45 @@ +#include <sys/types.h> +#include <sys/socket.h> +#include <netdb.h> +#include <stdio.h> +#include <string.h> +#include <stdint.h> +#include <unistd.h> +#include <stdbool.h> +#include <fcntl.h> +#include <stdlib.h> +#include <arpa/inet.h> +#include <netinet/in.h> + +#define _FAIL_EXIT -1 + +// Bind section of beej networking + +int main () { + + struct addrinfo hints; + struct addrinfo *res; + int sockfd; + int status; + memset(&hints, 0, sizeof(hints)); + hints.ai_family = AF_INET; + hints.ai_socktype = SOCK_STREAM; + hints.ai_flags = AI_PASSIVE; + status = getaddrinfo(NULL, "61000", &hints, &res); + if(status != 0) { + fprintf(stderr, "Error: %s\n", gai_strerror(status)); + exit(_FAIL_EXIT); + } + + sockfd = socket(res->ai_family, res->ai_socktype, res->ai_protocol); + if (sockfd == -1) { + exit(_FAIL_EXIT); + } + + int bstatus; + bstatus = bind(sockfd, res->ai_addr, res->ai_addrlen); + + fprintf(stdout, "%d\n", bstatus); + return 0; + +} |