OpenMoHAA 0.82.1
Loading...
Searching...
No Matches
alias.h
1/*
2===========================================================================
3Copyright (C) 2015 the OpenMoHAA team
4
5This file is part of OpenMoHAA source code.
6
7OpenMoHAA source code is free software; you can redistribute it
8and/or modify it under the terms of the GNU General Public License as
9published by the Free Software Foundation; either version 2 of the License,
10or (at your option) any later version.
11
12OpenMoHAA source code is distributed in the hope that it will be
13useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
14MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15GNU General Public License for more details.
16
17You should have received a copy of the GNU General Public License
18along with OpenMoHAA source code; if not, write to the Free Software
19Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20===========================================================================
21*/
22
23#pragma once
24
25#ifdef __cplusplus
26extern "C" {
27#endif
28
29//
30// public implementation
31//
32
33enum {
34 MAX_ALIAS_NAME_LENGTH = 40,
35 MAX_REAL_NAME_LENGTH = 128,
36 MAX_ALIASLIST_NAME_LENGTH = 40
37};
38
39typedef struct AliasListNode_s {
40 char alias_name[MAX_ALIAS_NAME_LENGTH];
41 char real_name[MAX_REAL_NAME_LENGTH];
42 float weight;
43
44 // Static alias info
45 byte stop_flag;
46 struct AliasListNode_s *next;
47
48 // Global alias info
49 float pitch;
50 float volume;
51 float pitchMod;
52 float volumeMod;
53 float dist;
54 float maxDist;
55 int channel;
56 int streamed;
57 qboolean forcesubtitle;
58 char *subtitle;
59} AliasListNode_t;
60
61typedef struct AliasList_s {
62 char name[MAX_ALIASLIST_NAME_LENGTH];
63 qboolean dirty;
64 int num_in_list;
65 AliasListNode_t **sorted_list;
66 AliasListNode_t *data_list;
67} AliasList_t;
68
69#if defined(APP_MODULE)
70
71const char *Alias_Find(const char *alias);
72qboolean Alias_Add(const char *alias, const char *name, const char *parameters);
73qboolean Alias_Delete(const char *alias);
74const char *Alias_FindRandom(const char *alias, AliasListNode_t **ret);
75void Alias_Dump(void);
76void Alias_Clear(void);
77AliasList_t *Alias_GetGlobalList();
78
79int S_ChannelNameToNum(const char *pszName);
80const char *S_ChannelNumToName(int iChannel);
81
82#endif
83
84//
85// private implementation
86//
87
88typedef struct AliasActorNode_s {
89 int actor_number;
90
91 int number_of_times_played;
92 byte been_played_this_loop;
93 int last_time_played;
94
95 struct AliasActorNode_s *next;
96} AliasActorNode_t;
97
98void Alias_ListClearActors(AliasList_t *list);
99AliasList_t *AliasList_New(const char *name);
100const char *Alias_ListFind(AliasList_t *list, const char *alias);
101AliasListNode_t *Alias_ListFindNode(AliasList_t *list, const char *alias);
102qboolean Alias_ListAdd(AliasList_t *list, const char *alias, const char *name, const char *parameters);
103const char *Alias_ListFindRandom(AliasList_t *list, const char *alias, AliasListNode_t **ret);
104void Alias_ListDump(AliasList_t *list);
105void Alias_ListClear(AliasList_t *list);
106void Alias_ListDelete(AliasList_t *list);
107void Alias_ListSort(AliasList_t *list);
108int Alias_IsGlobal(AliasListNode_t *node, int actor_number);
109AliasActorNode_t *Alias_FindActor(AliasListNode_t *node, int actor_number);
110void Alias_ListFindRandomRange(
111 AliasList_t *list, const char *alias, int *min_index, int *max_index, float *total_weight
112 );
113const char *Alias_ListFindDialog(AliasList_t *list, const char *alias);
114void Alias_ListUpdateDialog(AliasList_t *list, const char *alias);
115void Alias_ListAddActorDialog(AliasList_t *list, const char *alias);
116float randweight(void);
117
118#ifdef __cplusplus
119}
120#endif
Definition alias.h:88
Definition alias.h:39
Definition alias.h:61