File: sv_snd.c

package info (click to toggle)
openmohaa 0.81.1%2Bdfsg-2
  • links: PTS, VCS
  • area: contrib
  • in suites: trixie
  • size: 29,124 kB
  • sloc: ansic: 270,865; cpp: 250,173; sh: 234; asm: 141; xml: 64; makefile: 7
file content (120 lines) | stat: -rw-r--r-- 3,105 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/*
===========================================================================
Copyright (C) 2015 the OpenMoHAA team

This file is part of OpenMoHAA source code.

OpenMoHAA source code 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.

OpenMoHAA source code 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 OpenMoHAA source code; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
===========================================================================
*/

// sv_snd.c: Server sound

#include "server.h"

/*
===============
SV_ClientSound
===============
*/
void SV_ClientSound(client_t* client, vec3_t* org, int entnum, int channel, int sound_index, float volume, float mindist, float pitch, float maxdist, qboolean streamed) {
	server_sound_t* sound;

	if (client->state != CS_ACTIVE)
		return;

    if (client->number_of_server_sounds >= MAX_SERVER_SOUNDS)
        return;

	sound = &client->server_sounds[client->number_of_server_sounds];
	sound->stop_flag = 0;
	sound->entity_number = entnum;

	if (org)
	{
		VectorCopy(*org, sound->origin);
	}
	else
	{
		VectorClear(sound->origin);
	}

	sound->channel = channel;
	sound->volume = volume;
	sound->min_dist = mindist;
	sound->pitch = pitch;
	sound->maxDist = maxdist;
	sound->sound_index = sound_index;
	sound->streamed = streamed;
	client->number_of_server_sounds++;
}

/*
===============
SV_Sound
===============
*/
void SV_Sound( vec3_t *org, int entnum, int channel, const char *sound_name, float volume, float mindist, float pitch, float maxdist, qboolean streamed )
{
    int i;

    for (i = 0; i < svs.iNumClients; i++)
    {
        client_t* client = &svs.clients[i];
		if (client->state != CS_ACTIVE) {
			continue;
        }

		if (client->number_of_server_sounds >= MAX_SERVER_SOUNDS) {
			continue;
		}

        SV_ClientSound(client, org, entnum, channel, SV_SoundIndex(sound_name, streamed), volume, mindist, pitch, maxdist, streamed);
    }
}

/*
===============
SV_ClearSounds
===============
*/
void SV_ClearSounds( client_t *client )
{
	client->number_of_server_sounds = 0;
}

/*
===============
SV_StopSound
===============
*/
void SV_StopSound( int entnum, int channel )
{
	server_sound_t *server_sound;
	int i;
	client_t *client;

	for( client = svs.clients, i = 0; i < svs.iNumClients; client++, i++ )
	{
		if( client->state == CS_ACTIVE && client->number_of_server_sounds < MAX_SERVER_SOUNDS )
		{
			server_sound = &client->server_sounds[ client->number_of_server_sounds ];
			server_sound->stop_flag = qtrue;
			server_sound->entity_number = entnum;
			server_sound->channel = channel;
			client->number_of_server_sounds++;
		}
	}
}