File: ses.c

package info (click to toggle)
brltty 6.7-3.1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 31,240 kB
  • sloc: ansic: 148,859; java: 13,418; sh: 9,623; xml: 5,699; tcl: 2,634; makefile: 2,333; awk: 713; lisp: 366; python: 321; ml: 301
file content (110 lines) | stat: -rw-r--r-- 2,614 bytes parent folder | download | duplicates (3)
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
/*
 * BRLTTY - A background process providing access to the console screen (when in
 *          text mode) for a blind person using a refreshable braille display.
 *
 * Copyright (C) 1995-2024 by The BRLTTY Developers.
 *
 * BRLTTY comes with ABSOLUTELY NO WARRANTY.
 *
 * This is free software, placed under the terms of the
 * GNU Lesser General Public License, as published by the Free Software
 * Foundation; either version 2.1 of the License, or (at your option) any
 * later version. Please see the file LICENSE-LGPL for details.
 *
 * Web Page: http://brltty.app/
 *
 * This software is maintained by Dave Mielke <dave@mielke.cc>.
 */

#include "prologue.h"

#include <string.h>

#include "log.h"
#include "ses.h"
#include "defaults.h"

static const SessionEntry initialSessionEntry = {
  .number = 0,

  .trackScreenCursor = DEFAULT_TRACK_SCREEN_CURSOR,
  .hideScreenCursor = DEFAULT_HIDE_SCREEN_CURSOR,

  .ptrx = -1,
  .ptry = -1
};

static SessionEntry **sessionArray = NULL;
static unsigned int sessionLimit = 0;
static unsigned int sessionCount = 0;

SessionEntry *
getSessionEntry (int number) {
  int first = 0;
  int last = sessionCount - 1;

  while (first <= last) {
    int current = (first + last) / 2;
    SessionEntry *entry = sessionArray[current];
    if (number == entry->number) return entry;

    if (number < entry->number) {
      last = current - 1;
    } else {
      first = current + 1;
    }
  }

  if (sessionCount == sessionLimit) {
    unsigned int newLimit = sessionLimit? sessionLimit<<1: 0X10;
    SessionEntry **newArray;

    if ((newArray = realloc(sessionArray, ARRAY_SIZE(newArray, newLimit)))) {
      sessionArray = newArray;
      sessionLimit = newLimit;
    } else {
      logMallocError();
    }
  }

  if (sessionCount < sessionLimit) {
    SessionEntry *entry = malloc(sizeof(*entry));

    if (entry) {
      *entry = initialSessionEntry;
      entry->number = number;

      memmove(&sessionArray[first+1], &sessionArray[first],
              ARRAY_SIZE(sessionArray, sessionCount-first));
      sessionArray[first] = entry;
      sessionCount += 1;
      return entry;
    } else {
      logMallocError();
    }
  }

  {
    static SessionEntry fallbackEntry;
    static int initialized = 0;

    if (!initialized) {
      fallbackEntry = initialSessionEntry;
      initialized = 1;
    }

    return &fallbackEntry;
  }
}

void
deallocateSessionEntries (void) {
  if (sessionArray) {
    while (sessionCount > 0) free(sessionArray[--sessionCount]);
    free(sessionArray);
    sessionArray = NULL;
  } else {
    sessionCount = 0;
  }
  sessionLimit = 0;
}