Mercurial > ~dholland > hg > ag > index.cgi
view anagram/support/agref.cpp @ 8:ec2b657edf13
Add explicit lint-comment-style fallthrough annotations.
GCC now assumes that if you don't have these you're making a mistake,
which is annoying.
XXX: This changeset updates the AG output files only (by hand) and is
XXX: abusive - rebuilding them will erase the change. However, I need
XXX: to get things to build before I can try to get AG to issue the
XXX: annotations itself, so this seems like a reasonable expedient.
author | David A. Holland |
---|---|
date | Mon, 30 May 2022 23:51:43 -0400 |
parents | 13d2b8934445 |
children |
line wrap: on
line source
/********************************************************** The AnaGram Class Library The AgReference Class Copyright 1997 Parsifal Software. All Rights Reserved. See the file COPYING for license and usage terms. ***********************************************************/ #include "agref.h" void AgReferenceBase::doAssignmentLocks(const AgReferenceBase &r) { if (object!=0 && object->unlock()) { delete object; } object = r.object; if (object != 0) { object->lock(); } } AgReferenceBase::AgReferenceBase() : object(0) {} AgReferenceBase::AgReferenceBase(AgReferenceCount* object_) : object(object_) { if (object != 0) { object->lock(); } } AgReferenceBase::AgReferenceBase(const AgReferenceBase &r) : object(r.object) { if (object!= 0) { object->lock(); } } AgReferenceBase::~AgReferenceBase() { if (object!= 0 && object->unlock()) { delete object; } } int AgReferenceBase::exists() const { return object != 0; } void AgReferenceBase::discardData() { if (object && object->unlock()) { delete object; } object = 0; }