I've tried searching the docs and the code, but I'm unable to find what this is and therefore how to correct it.
Scenario:
I'm using the Ada SPARK vectors library and I have the following code:
package MyPackage
with SPARK_Mode => On
is
package New_Vectors is new Formal_Vectors (Index_Type => test, Element_Type => My_Element.Object);
type Object is private;
private
type Object is
record
Data : New_Vectors.Vector (Block_Vectors.Last_Count);
Identifier : Identifier_Range;
end record;
I get the error when the code calls:
function Make (Identifier : Identifier_Range) return Object is
begin
return (
Data => New_Vectors.Empty_Vector,
Identifier => Identifier);
end Make;
Pointing to Empty_Vector
. The difficulty is that Empty_Vector
defines the Capacity
as 0
which appears to be leading to the problem. Now I'm not sure then how to deal with that as Capacity
seems to be in the type definition (having looked in a-cofove.ads
).
So basically I'm stuck as to how to resolve this; or quite how to spot this happening in future.
Your analysis is correct. The error occurs because you attempt to assign an empty vector (i.e. a vector with capacity 0) to a vector with capacity
Block_Vectors.Last_Count
(which appears to be non-zero).You actually do not need to initialize the vector explicitly in order to use it. A default initialization (using
<>
, see, for example, here) suffices as shown in de example below.However, in order to prove the absence of runtime errors, you do need to explicitly clear the vector using
Clear
. TheEmpty_Vector
function can then be used to in assertions that check if a vector is empty or not as shown in the example below. The example can be shown to be free of runtime errors usinggnatprove
. For example by opening the prove settings via menu SPARK > Prove in GNAT Studio, selecting "Report checks moved" in the "General" section (top left) and then running the analysis by selecting "Execute" (bottom right).main.adb
output