mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Planner: don't return static data in fake_dc()
fake_dc() used to return a statically allocated dc with statically allocated samples. This is of course a questionable practice in the light of multi-threading / resource ownership. Once these problems were recognized, the parameter "alloc" was added. If set to true, the function would still return a statically allocated dc, but heap-allocated samples, which could then be copied in a different dc. All in all an ownership nightmare and a recipie for disaster. The returned static dc was only used as a pointer to the samples anyway. There are four callers of fake_dc() and they all have access to a dc-structure without samples. Therefore, change the semantics of fake_dc() to fill out the passed in dc. If the caller does not care about the samples, it can simply reset the sample number to zero after work. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
This commit is contained in:
parent
450f0992a0
commit
920ff15f71
7 changed files with 39 additions and 40 deletions
|
@ -592,9 +592,8 @@ void ProfileWidget2::plotDive(struct dive *d, bool force)
|
|||
// data that we have
|
||||
struct divecomputer *currentdc = select_dc(&displayed_dive);
|
||||
Q_ASSERT(currentdc);
|
||||
if (!currentdc || !currentdc->samples) {
|
||||
currentdc = fake_dc(currentdc, false);
|
||||
}
|
||||
if (!currentdc || !currentdc->samples)
|
||||
fake_dc(currentdc);
|
||||
|
||||
bool setpointflag = (currentdc->divemode == CCR) && prefs.pp_graphs.po2 && current_dive;
|
||||
bool sensorflag = setpointflag && prefs.show_ccr_sensors;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue