view anagram/support/assert.h @ 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 f5acaf0c8a29
line wrap: on
line source

/*
 * AnaGram, A System for Syntax Directed Programming
 * Copyright 1993-2002 Parsifal Software. All Rights Reserved.
 * Copyright 2006, 2007 David A. Holland. All Rights Reserved.
 * See the file COPYING for license and usage terms.
 *
 * assert.h
 */

#ifndef ASSERT_H
#define ASSERT_H

// to prevent recursive asserting
extern int no_assertions;

void badAssertion(const char *file, int line);
#define assert(p) \
	(((volatile int)(p)) ? (void)0 : badAssertion(__FILE__, __LINE__))


/*
 * This must be provided by each user interface and is NOT defined in
 * assert.cpp.
 */

void bailOut(const char *msg);

#endif /* ASSERT_H */