/*****************************************************************************/ /* */ /* asserts.c */ /* */ /* Assertions for the ld65 linker */ /* */ /* */ /* */ /* (C) 2003 Ullrich von Bassewitz */ /* Römerstrasse 52 */ /* D-70794 Filderstadt */ /* EMail: uz@cc65.org */ /* */ /* */ /* This software is provided 'as-is', without any expressed or implied */ /* warranty. In no event will the authors be held liable for any damages */ /* arising from the use of this software. */ /* */ /* Permission is granted to anyone to use this software for any purpose, */ /* including commercial applications, and to alter it and redistribute it */ /* freely, subject to the following restrictions: */ /* */ /* 1. The origin of this software must not be misrepresented; you must not */ /* claim that you wrote the original software. If you use this software */ /* in a product, an acknowledgment in the product documentation would be */ /* appreciated but is not required. */ /* 2. Altered source versions must be plainly marked as such, and must not */ /* be misrepresented as being the original software. */ /* 3. This notice may not be removed or altered from any source */ /* distribution. */ /* */ /*****************************************************************************/ /* common */ #include "assertdefs.h" #include "coll.h" #include "xmalloc.h" /* ld65 */ #include "asserts.h" #include "error.h" #include "expr.h" #include "fileio.h" #include "objdata.h" #include "spool.h" /*****************************************************************************/ /* Data */ /*****************************************************************************/ /* List with all assertions */ static Collection Assertions = STATIC_COLLECTION_INITIALIZER; /*****************************************************************************/ /* Code */ /*****************************************************************************/ Assertion* ReadAssertion (FILE* F, struct ObjData* O) /* Read an assertion from the given file */ { /* Allocate memory */ Assertion* A = xmalloc (sizeof (Assertion)); /* Read the fields from the file */ A->Expr = ReadExpr (F, O); A->Action = ReadVar (F); A->Msg = MakeGlobalStringId (O, ReadVar (F)); ReadFilePos (F, &A->Pos); /* Set remaining fields */ A->Obj = O; /* Add the assertion to the global list */ CollAppend (&Assertions, A); /* Return the new struct */ return A; } void CheckAssertions (void) /* Check all assertions */ { unsigned I; /* Walk over all assertions */ for (I = 0; I < CollCount (&Assertions); ++I) { /* Get the assertion */ Assertion* A = CollAtUnchecked (&Assertions, I); /* If the expression is not constant, we're not able to handle it */ if (!IsConstExpr (A->Expr)) { Warning ("Cannot evaluate assertion in module `%s', line %lu", GetSourceFileName (A->Obj, A->Pos.Name), A->Pos.Line); } else if (GetExprVal (A->Expr) == 0) { /* Assertion failed */ const char* Module = GetSourceFileName (A->Obj, A->Pos.Name); const char* Message = GetString (A->Msg); switch (A->Action) { case ASSERT_ACT_WARN: Warning ("%s(%lu): %s", Module, A->Pos.Line, Message); break; case ASSERT_ACT_ERROR: Error ("%s(%lu): %s", Module, A->Pos.Line, Message); break; default: Internal ("Invalid assertion action (%u) in module `%s', " "line %lu (file corrupt?)", A->Action, Module, A->Pos.Line); break; } } } }