336 lines
12 KiB
C++
Executable file
336 lines
12 KiB
C++
Executable file
/******************************************************************************\
|
|
* \copyright (c) 2004-2014
|
|
* \author Volker Fischer
|
|
*
|
|
|
|
\mainpage Jamulus source code documentation
|
|
|
|
\section intro_sec Introduction
|
|
|
|
The Jamulus software enables musicians to perform real-time jam sessions over the
|
|
internet. There is one server running the Jamulus server software which collects
|
|
the audio data from each Jamulus client, mixes the audio data and sends the mix
|
|
back to each client.
|
|
|
|
|
|
Prefix definitions for the GUI:
|
|
|
|
label: lbl
|
|
combo box: cbx
|
|
line edit: edt
|
|
list view: lvw
|
|
check box: chb
|
|
radio button: rbt
|
|
button: but
|
|
text view: txv
|
|
slider: sld
|
|
LED: led
|
|
group box: grb
|
|
pixmap label: pxl
|
|
LED bar: lbr
|
|
|
|
******************************************************************************
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it under
|
|
* the terms of the GNU General Public License as published by the Free Software
|
|
* Foundation; either version 2 of the License, or (at your option) any later
|
|
* version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
* details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along with
|
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*
|
|
\******************************************************************************/
|
|
|
|
#if !defined ( GLOBAL_H__3B123453_4344_BB2B_23E7A0D31912__INCLUDED_ )
|
|
#define GLOBAL_H__3B123453_4344_BB2B_23E7A0D31912__INCLUDED_
|
|
|
|
#include <QString>
|
|
#include <QEvent>
|
|
#include <QDebug>
|
|
#include <stdio.h>
|
|
#include <math.h>
|
|
#include <string>
|
|
#ifndef _WIN32
|
|
# include <unistd.h> // solves a compile problem on recent Ubuntu
|
|
#endif
|
|
#ifdef HAVE_CONFIG_H
|
|
# include "config.h"
|
|
#endif
|
|
|
|
|
|
/* Definitions ****************************************************************/
|
|
// The receive socket should be put in a high priority thread to ensure the GUI
|
|
// does not effect the stability of the audio stream (e.g. if the GUI is on
|
|
// high load because of a table update, the incoming network packets must still
|
|
// be put in the jitter buffer with highest priority).
|
|
// Since the new code is still in "experimental state", we introduced this macro
|
|
// to enable/disable the new code.
|
|
//
|
|
// I disabled the new code again since it seems not to improve the situation
|
|
// much. Maybe things must be tweaked for it to work correctly. Since the more
|
|
// threads we have the higher is the risk of software crashes, I will only
|
|
// enable the new code on significant performance gain.
|
|
//
|
|
//#define ENABLE_RECEIVE_SOCKET_IN_SEPARATE_THREAD
|
|
#undef ENABLE_RECEIVE_SOCKET_IN_SEPARATE_THREAD
|
|
|
|
// define this macro to get debug output
|
|
//#define _DEBUG_
|
|
#undef _DEBUG_
|
|
|
|
// version and application name (use version from qt prject file)
|
|
#undef VERSION
|
|
#define VERSION APP_VERSION
|
|
#define APP_NAME "Jamulus"
|
|
|
|
// Windows registry key name of auto run entry for the server
|
|
#define AUTORUN_SERVER_REG_NAME "Jamulus server"
|
|
|
|
// default names of the ini-file for client and server
|
|
#define DEFAULT_INI_FILE_NAME "Jamulus.ini"
|
|
#define DEFAULT_INI_FILE_NAME_SERVER "Jamulusserver.ini"
|
|
|
|
// file name for logging file
|
|
#define DEFAULT_LOG_FILE_NAME "Jamulussrvlog.txt"
|
|
|
|
// default server address
|
|
#define DEFAULT_SERVER_ADDRESS "jamulus.dyndns.org"
|
|
#define SELECT_SERVER_ADDRESS(a, b) ((a) ? (DEFAULT_SERVER_ADDRESS) : (b))
|
|
|
|
// download URL
|
|
#define LLCON_DOWNLOAD_URL "http://sourceforge.net/projects/llcon/files"
|
|
|
|
// defined port number for client and server
|
|
#define LLCON_DEFAULT_PORT_NUMBER 22124
|
|
|
|
// system sample rate (the sound card and audio coder works on this sample rate)
|
|
#define SYSTEM_SAMPLE_RATE_HZ 48000 // Hz
|
|
|
|
// System block size, this is the block size on which the audio coder works.
|
|
// All other block sizes must be a multiple of this size
|
|
#define SYSTEM_FRAME_SIZE_SAMPLES 128
|
|
|
|
#define SYSTEM_BLOCK_DURATION_MS_FLOAT \
|
|
( static_cast<double> ( SYSTEM_FRAME_SIZE_SAMPLES ) / \
|
|
SYSTEM_SAMPLE_RATE_HZ * 1000 )
|
|
|
|
// define the allowed audio frame size factors (since the
|
|
// "SYSTEM_FRAME_SIZE_SAMPLES" is quite small, it may be that on some
|
|
// computers a larger value is required)
|
|
#define FRAME_SIZE_FACTOR_PREFERRED 1 // 128 (for frame size 128)
|
|
#define FRAME_SIZE_FACTOR_DEFAULT 2 // 256 (for frame size 128)
|
|
#define FRAME_SIZE_FACTOR_SAFE 4 // 512 (for frame size 128)
|
|
|
|
// low complexity CELT encoder (if defined)
|
|
#define USE_LOW_COMPLEXITY_CELT_ENC
|
|
|
|
// define the minimum allowed number of coded bytes for CELT (the encoder
|
|
// gets in trouble if the value is too low)
|
|
#define CELT_MINIMUM_NUM_BYTES 10
|
|
|
|
// define the maximum mono audio buffer size at a sample rate
|
|
// of 48 kHz, this is important for defining the maximum number
|
|
// of bytes to be expected from the network interface
|
|
|
|
// TODO check why this number is so large...?
|
|
|
|
#define MAX_MONO_AUD_BUFF_SIZE_AT_48KHZ 4096
|
|
|
|
// Maximum block size for network input buffer. Consider a maximum sample rate
|
|
// of 48 kHz and two audio channels and two bytes per sample.
|
|
#define MAX_SIZE_BYTES_NETW_BUF ( MAX_MONO_AUD_BUFF_SIZE_AT_48KHZ * 4 )
|
|
|
|
// minimum/maximum network buffer size (which can be chosen by slider)
|
|
#define MIN_NET_BUF_SIZE_NUM_BL 1 // number of blocks
|
|
#define MAX_NET_BUF_SIZE_NUM_BL 20 // number of blocks
|
|
#define AUTO_NET_BUF_SIZE_FOR_PROTOCOL ( MAX_NET_BUF_SIZE_NUM_BL + 1 ) // auto set parameter (only used for protocol)
|
|
|
|
// default network buffer size
|
|
#define DEF_NET_BUF_SIZE_NUM_BL 10 // number of blocks
|
|
|
|
// audio mixer fader maximum value
|
|
#define AUD_MIX_FADER_MAX 100
|
|
|
|
// maximum number of recognized sound cards installed in the system,
|
|
// definition for "no device"
|
|
#define MAX_NUMBER_SOUND_CARDS 30
|
|
#define INVALID_SNC_CARD_DEVICE -1
|
|
|
|
// define the maximum number of audio channel for input/output we can store
|
|
// channel infos for (and therefore this is the maximum number of entries in
|
|
// the channel selection combo box regardless of the actual available number
|
|
// of channels by the audio device)
|
|
#define MAX_NUM_IN_OUT_CHANNELS 32
|
|
|
|
// maximum number of elemts in the server address combo box
|
|
#define MAX_NUM_SERVER_ADDR_ITEMS 6
|
|
|
|
// maximum number of fader settings to be stored (together with the fader tags)
|
|
#define MAX_NUM_STORED_FADER_SETTINGS 20
|
|
|
|
// defines for LED input level meter
|
|
#define NUM_STEPS_INP_LEV_METER 8
|
|
#define RED_BOUND_INP_LEV_METER 7
|
|
#define YELLOW_BOUND_INP_LEV_METER 5
|
|
|
|
// maximum number of internet connections (channels)
|
|
// if you want to change this paramter, there has to be done code modifications
|
|
// on other places, too! The code tag "MAX_NUM_CHANNELS_TAG" shows these places
|
|
// (just search for the tag in the entire code)
|
|
#define MAX_NUM_CHANNELS 20 // max number channels for server
|
|
|
|
// actual number of used channels in the server
|
|
// this parameter can safely be changed from 1 to MAX_NUM_CHANNELS
|
|
// without any other changes in the code
|
|
#define DEFAULT_USED_NUM_CHANNELS 7 // default used number channels for server
|
|
|
|
// maximum number of servers registered in the server list
|
|
#define MAX_NUM_SERVERS_IN_SERVER_LIST 100
|
|
|
|
// defines the time interval at which the ping time is updated in the GUI
|
|
#define PING_UPDATE_TIME_MS 500 // ms
|
|
|
|
// defines the time interval at which the ping time is updated for the server
|
|
// list
|
|
#define PING_UPDATE_TIME_SERVER_LIST_MS 2000 // ms
|
|
|
|
// time-out until a registered server is deleted from the server list if no
|
|
// new registering was made in minutes
|
|
#define SERVLIST_TIME_OUT_MINUTES 60 // minutes
|
|
|
|
// poll time for server list (to check if entries are time-out)
|
|
#define SERVLIST_POLL_TIME_MINUTES 1 // minute
|
|
|
|
// time interval for sending ping messages to servers in the server list
|
|
#define SERVLIST_UPDATE_PING_SERVERS_MS 59000 // ms
|
|
|
|
// time until a slave server registers in the server list
|
|
#define SERVLIST_REGIST_INTERV_MINUTES 15 // minutes
|
|
|
|
|
|
// length of the moving average buffer for response time measurement
|
|
#define TIME_MOV_AV_RESPONSE_SECONDS 30 // seconds
|
|
|
|
|
|
// Maximum length of fader tag and text message strings (Since for chat messages
|
|
// some HTML code is added, we also have to define a second length which includes
|
|
// this additionl HTML code. Right now the length of the HTML code is approx. 66
|
|
// character. Here, we add some headroom to this number)
|
|
#define MAX_LEN_FADER_TAG 16
|
|
#define MAX_LEN_CHAT_TEXT 1600
|
|
#define MAX_LEN_CHAT_TEXT_PLUS_HTML 1800
|
|
#define MAX_LEN_SERVER_NAME 20
|
|
#define MAX_LEN_SERVER_TOPIC 32
|
|
#define MAX_LEN_SERVER_CITY 20
|
|
|
|
// common tool tip bottom line text
|
|
#define TOOLTIP_COM_END_TEXT tr ( \
|
|
"<br><div align=right><font size=-1><i>" \
|
|
"For more information use the ""What's " \
|
|
"This"" help (? menu, right mouse button or Shift+F1)" \
|
|
"</i></font></div>" )
|
|
|
|
#define _MAXSHORT 32767
|
|
#define _MAXBYTE 255 // binary: 11111111
|
|
#define _MINSHORT ( -32768 )
|
|
|
|
#if HAVE_STDINT_H
|
|
# include <stdint.h>
|
|
#elif HAVE_INTTYPES_H
|
|
# include <inttypes.h>
|
|
#elif defined ( _WIN32 )
|
|
typedef __int64 int64_t;
|
|
typedef __int32 int32_t;
|
|
typedef __int16 int16_t;
|
|
typedef unsigned __int64 uint64_t;
|
|
typedef unsigned __int32 uint32_t;
|
|
typedef unsigned __int16 uint16_t;
|
|
typedef unsigned __int8 uint8_t;
|
|
#else
|
|
typedef long long int64_t;
|
|
typedef int int32_t;
|
|
typedef short int16_t;
|
|
typedef unsigned long long uint64_t;
|
|
typedef unsigned int uint32_t;
|
|
typedef unsigned short uint16_t;
|
|
typedef unsigned char uint8_t;
|
|
#endif
|
|
|
|
|
|
/* Pseudo enum definitions -------------------------------------------------- */
|
|
// definition for custom event
|
|
#define MS_PACKET_RECEIVED 0
|
|
|
|
|
|
/* Classes ********************************************************************/
|
|
class CGenErr
|
|
{
|
|
public:
|
|
CGenErr ( QString strNewErrorMsg, QString strNewErrorType = "" ) :
|
|
strErrorMsg ( strNewErrorMsg ), strErrorType ( strNewErrorType ) {}
|
|
|
|
QString GetErrorText()
|
|
{
|
|
// return formatted error text
|
|
if ( strErrorType.isEmpty() )
|
|
{
|
|
return strErrorMsg;
|
|
}
|
|
else
|
|
{
|
|
return strErrorType + ": " + strErrorMsg;
|
|
}
|
|
}
|
|
|
|
protected:
|
|
QString strErrorMsg;
|
|
QString strErrorType;
|
|
};
|
|
|
|
class CCustomEvent : public QEvent
|
|
{
|
|
public:
|
|
CCustomEvent ( int iNewMeTy, int iNewSt, int iNewChN = 0 ) :
|
|
QEvent ( QEvent::Type ( QEvent::User + 11 ) ), iMessType ( iNewMeTy ), iStatus ( iNewSt ),
|
|
iChanNum ( iNewChN ) {}
|
|
|
|
int iMessType;
|
|
int iStatus;
|
|
int iChanNum;
|
|
};
|
|
|
|
|
|
/* Prototypes for global functions ********************************************/
|
|
// command line parsing, TODO do not declare functions globally but in a class
|
|
QString UsageArguments ( char** argv );
|
|
|
|
bool GetFlagArgument ( char** argv,
|
|
int& i,
|
|
QString strShortOpt,
|
|
QString strLongOpt );
|
|
|
|
bool GetStringArgument ( QTextStream& tsConsole,
|
|
int argc,
|
|
char** argv,
|
|
int& i,
|
|
QString strShortOpt,
|
|
QString strLongOpt,
|
|
QString& strArg );
|
|
|
|
bool GetNumericArgument ( QTextStream& tsConsole,
|
|
int argc,
|
|
char** argv,
|
|
int& i,
|
|
QString strShortOpt,
|
|
QString strLongOpt,
|
|
double rRangeStart,
|
|
double rRangeStop,
|
|
double& rValue);
|
|
|
|
#endif /* !defined ( GLOBAL_H__3B123453_4344_BB2B_23E7A0D31912__INCLUDED_ ) */
|