mirror of
https://github.com/JulianGro/overte.git
synced 2025-08-29 16:27:39 +02:00
Merge remote-tracking branch 'origin'
This commit is contained in:
commit
ba683de026
243 changed files with 124 additions and 176 deletions
|
@ -1,16 +1,8 @@
|
|||
cmake_minimum_required(VERSION 2.8)
|
||||
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${CMAKE_SOURCE_DIR}/cmake/modules/")
|
||||
|
||||
project(hifi)
|
||||
|
||||
set(GLM_ROOT_DIR ${CMAKE_SOURCE_DIR}/external)
|
||||
set(LODEPNG_ROOT_DIR ${CMAKE_SOURCE_DIR}/external/LodePNG)
|
||||
set(PORTAUDIO_DIR ${CMAKE_SOURCE_DIR}/external/portaudio)
|
||||
|
||||
set(HIFI_SHARED_DIR ${CMAKE_SOURCE_DIR}/shared/src)
|
||||
file(GLOB HIFI_SHARED_SRCS ${HIFI_SHARED_DIR}/*.cpp ${HIFI_SHARED_DIR}/*.h)
|
||||
|
||||
add_subdirectory(interface)
|
||||
add_subdirectory(space)
|
||||
add_subdirectory(domain)
|
||||
add_subdirectory(mixer)
|
||||
add_subdirectory(space)
|
||||
add_subdirectory(interface)
|
10
LinkHifiShared.cmake
Normal file
10
LinkHifiShared.cmake
Normal file
|
@ -0,0 +1,10 @@
|
|||
MACRO(LINK_HIFI_SHARED_LIBRARY TARGET)
|
||||
if (NOT TARGET HifiShared)
|
||||
add_subdirectory(../shared ../shared)
|
||||
endif (NOT TARGET HifiShared)
|
||||
|
||||
include_directories(../shared/src)
|
||||
get_directory_property(HIFI_SHARED_LIBRARY DIRECTORY ../shared DEFINITION HIFI_SHARED_LIBRARY)
|
||||
add_dependencies(${TARGET} ${HIFI_SHARED_LIBRARY})
|
||||
target_link_libraries(${TARGET} ${HIFI_SHARED_LIBRARY})
|
||||
ENDMACRO(LINK_HIFI_SHARED_LIBRARY _target)
|
|
@ -4,4 +4,7 @@ project(domain)
|
|||
|
||||
file(GLOB DOMAIN_SRCS src/*.cpp src/*.h)
|
||||
|
||||
add_executable(domain ${DOMAIN_SRCS})
|
||||
add_executable(domain ${DOMAIN_SRCS})
|
||||
|
||||
include(../LinkHifiShared.cmake)
|
||||
link_hifi_shared_library(domain)
|
|
@ -27,13 +27,11 @@
|
|||
#include <arpa/inet.h>
|
||||
#include <fcntl.h>
|
||||
#include <sys/time.h>
|
||||
#include "UDPSocket.h"
|
||||
|
||||
|
||||
const int LISTENING_UDP_PORT = 40102;
|
||||
const int DOMAIN_LISTEN_PORT = 40102;
|
||||
const char DESTINATION_IP[] = "127.0.0.1";
|
||||
sockaddr_in address, dest_address;
|
||||
socklen_t destLength = sizeof( dest_address );
|
||||
|
||||
|
||||
const int MAX_PACKET_SIZE = 1500;
|
||||
char packet_data[MAX_PACKET_SIZE];
|
||||
|
@ -52,9 +50,10 @@ struct AgentList {
|
|||
} agents[MAX_AGENTS];
|
||||
|
||||
int num_agents = 0;
|
||||
|
||||
int lastActiveCount = 0;
|
||||
|
||||
UDPSocket domainSocket = UDPSocket(DOMAIN_LISTEN_PORT);
|
||||
|
||||
double diffclock(timeval clock1,timeval clock2)
|
||||
{
|
||||
double diffms = (clock2.tv_sec - clock1.tv_sec) * 1000.0;
|
||||
|
@ -62,43 +61,6 @@ double diffclock(timeval clock1,timeval clock2)
|
|||
return diffms;
|
||||
}
|
||||
|
||||
int network_init()
|
||||
{
|
||||
// Create socket
|
||||
int handle = socket( AF_INET, SOCK_DGRAM, IPPROTO_UDP );
|
||||
|
||||
if ( handle <= 0 )
|
||||
{
|
||||
printf( "failed to create socket\n" );
|
||||
return false;
|
||||
}
|
||||
|
||||
// Bind socket to port
|
||||
address.sin_family = AF_INET;
|
||||
address.sin_addr.s_addr = INADDR_ANY;
|
||||
address.sin_port = htons( (unsigned short) LISTENING_UDP_PORT );
|
||||
|
||||
if ( bind( handle, (const sockaddr*) &address, sizeof(sockaddr_in) ) < 0 )
|
||||
{
|
||||
printf( "failed to bind socket\n" );
|
||||
return false;
|
||||
}
|
||||
|
||||
// Set socket as non-blocking
|
||||
int nonBlocking = 1;
|
||||
if ( fcntl( handle, F_SETFL, O_NONBLOCK, nonBlocking ) == -1 )
|
||||
{
|
||||
printf( "failed to set non-blocking socket\n" );
|
||||
return false;
|
||||
}
|
||||
|
||||
dest_address.sin_family = AF_INET;
|
||||
dest_address.sin_addr.s_addr = inet_addr(DESTINATION_IP);
|
||||
dest_address.sin_port = htons( (unsigned short) LISTENING_UDP_PORT );
|
||||
|
||||
return handle;
|
||||
}
|
||||
|
||||
int addAgent(uint32_t ip, in_port_t port, char agentType, float x, float y, float z) {
|
||||
// Search for agent in list and add if needed
|
||||
int i = 0;
|
||||
|
@ -136,9 +98,9 @@ void update_agent_list(timeval now) {
|
|||
}
|
||||
}
|
||||
|
||||
void send_agent_list(int handle, sockaddr_in * dest_address) {
|
||||
void send_agent_list(sockaddr_in *agentAddrPointer) {
|
||||
int i, length = 0;
|
||||
ssize_t sent_bytes;
|
||||
ssize_t sentBytes;
|
||||
char buffer[MAX_PACKET_SIZE];
|
||||
char * address;
|
||||
char portstring[10];
|
||||
|
@ -163,10 +125,11 @@ void send_agent_list(int handle, sockaddr_in * dest_address) {
|
|||
numSent++;
|
||||
}
|
||||
}
|
||||
|
||||
if (length > 1) {
|
||||
sent_bytes = (ssize_t) sendto( handle, (const char*)buffer, length,
|
||||
0, (sockaddr *) dest_address, sizeof(sockaddr_in) );
|
||||
if (sent_bytes < length)
|
||||
sentBytes = domainSocket.send(agentAddrPointer, buffer, length);
|
||||
|
||||
if (sentBytes < length)
|
||||
std::cout << "Error sending agent list!\n";
|
||||
else if (numSent != lastActiveCount) {
|
||||
std::cout << numSent << " Active Agents\n";
|
||||
|
@ -178,43 +141,30 @@ void send_agent_list(int handle, sockaddr_in * dest_address) {
|
|||
|
||||
int main(int argc, const char * argv[])
|
||||
{
|
||||
ssize_t received_bytes = 0;
|
||||
//int sent_bytes = 0;
|
||||
//int packet_size = 0;
|
||||
timeval time, last_time;
|
||||
ssize_t receivedBytes = 0;
|
||||
timeval time, last_time;
|
||||
sockaddr_in agentAddress;
|
||||
|
||||
int handle = network_init();
|
||||
if (!handle) {
|
||||
std::cout << "Failed to create network.\n";
|
||||
return 0;
|
||||
} else {
|
||||
std::cout << "DomainServer started, listening on port " << LISTENING_UDP_PORT << "\n";
|
||||
}
|
||||
gettimeofday(&last_time, NULL);
|
||||
|
||||
while (1) {
|
||||
received_bytes = recvfrom(handle, (char*)packet_data, MAX_PACKET_SIZE,
|
||||
0, (sockaddr*)&dest_address, &destLength );
|
||||
if (received_bytes > 0) {
|
||||
//std::cout << "Packet from: " << inet_ntoa(dest_address.sin_addr)
|
||||
//<< " " << packet_data << "\n";
|
||||
while (true) {
|
||||
if (domainSocket.receive(&agentAddress, packet_data, &receivedBytes)) {
|
||||
float x,y,z;
|
||||
char agentType;
|
||||
sscanf(packet_data, "%c %f,%f,%f", &agentType, &x, &y, &z);
|
||||
if (addAgent(dest_address.sin_addr.s_addr, ntohs(dest_address.sin_port), agentType, x, y, z)) {
|
||||
if (addAgent(agentAddress.sin_addr.s_addr, ntohs(agentAddress.sin_port), agentType, x, y, z)) {
|
||||
std::cout << "Added Agent, type " << agentType << " from " <<
|
||||
inet_ntoa(dest_address.sin_addr) << ":" << ntohs(dest_address.sin_port) << "\n";
|
||||
inet_ntoa(agentAddress.sin_addr) << ":" << ntohs(agentAddress.sin_port) << "\n";
|
||||
}
|
||||
// Reply with packet listing nearby active agents
|
||||
send_agent_list(handle, &dest_address);
|
||||
send_agent_list(&agentAddress);
|
||||
}
|
||||
|
||||
gettimeofday(&time, NULL);
|
||||
if (diffclock(last_time, time) > LOGOFF_CHECK_INTERVAL) {
|
||||
gettimeofday(&last_time, NULL);
|
||||
update_agent_list(last_time);
|
||||
}
|
||||
|
||||
usleep(10000);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -1,5 +1,10 @@
|
|||
cmake_minimum_required(VERSION 2.8)
|
||||
|
||||
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${CMAKE_CURRENT_SOURCE_DIR}/cmake/modules/")
|
||||
set(GLM_ROOT_DIR ${CMAKE_CURRENT_SOURCE_DIR}/external)
|
||||
set(LODEPNG_ROOT_DIR ${CMAKE_CURRENT_SOURCE_DIR}/external/LodePNG)
|
||||
set(PORTAUDIO_DIR ${CMAKE_CURRENT_SOURCE_DIR}/external/portaudio)
|
||||
|
||||
project(interface)
|
||||
|
||||
if (APPLE)
|
||||
|
@ -13,7 +18,9 @@ configure_file(InterfaceConfig.h.in ${PROJECT_BINARY_DIR}/includes/InterfaceConf
|
|||
|
||||
file(GLOB INTERFACE_SRCS src/*.cpp src/*.h)
|
||||
|
||||
add_executable(interface ${INTERFACE_SRCS} ${HIFI_SHARED_SRCS})
|
||||
add_executable(interface MACOSX_BUNDLE ${INTERFACE_SRCS})
|
||||
include(../LinkHifiShared.cmake)
|
||||
link_hifi_shared_library(interface)
|
||||
|
||||
find_package(OpenGL REQUIRED)
|
||||
find_package(GLUT REQUIRED)
|
||||
|
@ -22,7 +29,6 @@ find_package(LodePNG REQUIRED)
|
|||
|
||||
include_directories(
|
||||
${PROJECT_BINARY_DIR}/includes
|
||||
${HIFI_SHARED_DIR}
|
||||
${OPENGL_INCLUDE_DIRS}
|
||||
${GLUT_INCLUDE_DIRS}
|
||||
${GLM_INCLUDE_DIRS}
|
||||
|
@ -65,4 +71,9 @@ if (UNIX AND NOT APPLE)
|
|||
${JACK_LIBRARIES}
|
||||
${ALSA_LIBRARIES}
|
||||
)
|
||||
endif (UNIX AND NOT APPLE)
|
||||
endif (UNIX AND NOT APPLE)
|
||||
|
||||
INSTALL(TARGETS interface
|
||||
BUNDLE DESTINATION ${CMAKE_CURRENT_BINARY_DIR}/install COMPONENT Runtime
|
||||
RUNTIME DESTINATION ${CMAKE_CURRENT_BINARY_DIR}/install COMPONENT Runtime
|
||||
)
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue