diff options
author | Kirill Volinsky <mataes2007@gmail.com> | 2015-04-30 19:44:39 +0000 |
---|---|---|
committer | Kirill Volinsky <mataes2007@gmail.com> | 2015-04-30 19:44:39 +0000 |
commit | 157aa0dfbddd63f75f7eb7c1a8162df960543a64 (patch) | |
tree | d4f3efc24f1ee672ed774067ad6044226924da0c /plugins/Alarms/src/alarmlist.cpp | |
parent | 75cb4a995e44e1ebd1a009f344ab7df00c5c65ba (diff) |
minus critical section
git-svn-id: http://svn.miranda-ng.org/main/trunk@13315 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'plugins/Alarms/src/alarmlist.cpp')
-rw-r--r-- | plugins/Alarms/src/alarmlist.cpp | 53 |
1 files changed, 14 insertions, 39 deletions
diff --git a/plugins/Alarms/src/alarmlist.cpp b/plugins/Alarms/src/alarmlist.cpp index 41ae865577..cd60fe2a50 100644 --- a/plugins/Alarms/src/alarmlist.cpp +++ b/plugins/Alarms/src/alarmlist.cpp @@ -2,7 +2,7 @@ #include "alarmlist.h"
AlarmList alarms;
-CRITICAL_SECTION alarm_cs;
+mir_cs alarm_cs;
unsigned short next_alarm_id = 1; // 0 is used for invalid id
@@ -41,9 +41,8 @@ void copy_alarm_data(ALARM *dest, ALARM *src) { }
void GetPluginTime(SYSTEMTIME *t) {
- EnterCriticalSection(&alarm_cs);
+ mir_cslock lck(alarm_cs);
*t = last_check;
- LeaveCriticalSection(&alarm_cs);
}
int MinutesInFuture(SYSTEMTIME time, Occurrence occ) {
@@ -184,7 +183,7 @@ void LoadAlarms() { SYSTEMTIME now;
GetLocalTime(&now);
- EnterCriticalSection(&alarm_cs);
+ mir_cslock lck(alarm_cs);
alarms.clear();
for(int i = 0; i < num_alarms; i++) {
@@ -279,14 +278,13 @@ void LoadAlarms() { }
free_alarm_data(&alarm);
}
- LeaveCriticalSection(&alarm_cs);
}
void SaveAlarms() {
int index = 0;
char buff[256];
- EnterCriticalSection(&alarm_cs);
+ mir_cslock lck(alarm_cs);
ALARM *i;
for(alarms.reset(); i = alarms.current(); alarms.next(), index++) {
@@ -348,56 +346,47 @@ void SaveAlarms() { db_set_dw(0, MODULE, buff, i->flags);
}
db_set_w(0, MODULE, "Count", index);
-
- LeaveCriticalSection(&alarm_cs);
}
void copy_list(AlarmList ©) {
copy.clear();
ALARM *i;
- EnterCriticalSection(&alarm_cs);
+ mir_cslock lck(alarm_cs);
for(alarms.reset(); i = alarms.current(); alarms.next())
copy.push_back(i);
-
- LeaveCriticalSection(&alarm_cs);
}
void copy_list(AlarmList ©, SYSTEMTIME &start, SYSTEMTIME &end) {
copy.clear();
ALARM *i;
- EnterCriticalSection(&alarm_cs);
+ mir_cslock lck(alarm_cs);
for(alarms.reset(); i = alarms.current(); alarms.next())
if (IsBetween(i->time, start, end))
copy.push_back(i);
-
- LeaveCriticalSection(&alarm_cs);
}
void set_list(AlarmList ©) {
- EnterCriticalSection(&alarm_cs);
+ mir_cslock lck(alarm_cs);
alarms.clear();
ALARM *i;
for(copy.reset(); i = copy.current(); copy.next())
alarms.push_back(i);
- LeaveCriticalSection(&alarm_cs);
-
SaveAlarms();
}
void append_to_list(ALARM *alarm) {
- EnterCriticalSection(&alarm_cs);
+ mir_cslock lck(alarm_cs);
if (!alarm->id)
alarm->id = next_alarm_id++;
alarms.push_back(alarm);
- LeaveCriticalSection(&alarm_cs);
SaveAlarms();
}
void alter_alarm_list(ALARM *alarm) {
bool found = false;
- EnterCriticalSection(&alarm_cs);
+ mir_cslock lck(alarm_cs);
if (alarm->id != 0) {
ALARM *i;
for(alarms.reset(); i = alarms.current(); alarms.next()) {
@@ -414,13 +403,11 @@ void alter_alarm_list(ALARM *alarm) { alarms.push_back(alarm);
}
- LeaveCriticalSection(&alarm_cs);
-
SaveAlarms();
}
void remove(unsigned short alarm_id) {
- EnterCriticalSection(&alarm_cs);
+ mir_cslock lck(alarm_cs);
ALARM *i;
for(alarms.reset(); i = alarms.current(); alarms.next()) {
if (i->id == alarm_id) {
@@ -428,13 +415,12 @@ void remove(unsigned short alarm_id) { break;
}
}
- LeaveCriticalSection(&alarm_cs);
SaveAlarms();
}
void suspend(unsigned short alarm_id) {
- EnterCriticalSection(&alarm_cs);
+ mir_cslock lck(alarm_cs);
ALARM *i;
for(alarms.reset(); i = alarms.current(); alarms.next()) {
if (i->id == alarm_id && i->occurrence != OC_ONCE) {
@@ -442,7 +428,6 @@ void suspend(unsigned short alarm_id) { break;
}
}
- LeaveCriticalSection(&alarm_cs);
SaveAlarms();
}
@@ -592,7 +577,7 @@ void CheckAlarms() { // put triggered alarms in another list - so we don't keep the critical section locked for longer than necessary
AlarmList triggered_list, remove_list;
- EnterCriticalSection(&alarm_cs);
+ mir_cslock lck(alarm_cs);
ALARM *i;
for(alarms.reset(); i = alarms.current(); alarms.next()) {
if (!UpdateAlarm(i->time, i->occurrence)) {
@@ -624,7 +609,6 @@ void CheckAlarms() { WriteLastCheckTime();
startup = false;
- LeaveCriticalSection(&alarm_cs);
for(triggered_list.reset(); i = triggered_list.current(); triggered_list.next())
DoAlarm(i);
@@ -667,8 +651,6 @@ int IdleChanged(WPARAM, LPARAM lParam) void InitList()
{
- InitializeCriticalSection(&alarm_cs);
-
SkinAddNewSoundEx("Triggered1", LPGEN("Alarms"), LPGEN("Alert 1"));
SkinAddNewSoundEx("Triggered2", LPGEN("Alarms"), LPGEN("Alert 2"));
SkinAddNewSoundEx("Triggered3", LPGEN("Alarms"), LPGEN("Alert 3"));
@@ -703,19 +685,12 @@ void DeinitList() { DeinitAlarmWin();
// i don't think this should be necessary, but...
- EnterCriticalSection(&alarm_cs);
+ mir_cslock lck(alarm_cs);
KillTimer(0, timer_id);
- LeaveCriticalSection(&alarm_cs);
DestroyHookableEvent(hAlarmTriggeredEvent);
DestroyServiceFunction(hAddAlarmService);
- SaveAlarms(); // we may have erased some 'cause they were once-offs that were triggered
-
- //WriteLastCheckTime(); // moved to the CheckAlarms function - for virt db and general crash problems
-
- // delete this after save alarms above
- DeleteCriticalSection(&alarm_cs);
-
+ SaveAlarms(); // we may have erased some 'cause they were once-offs that were triggeredf
}
|