J'ai défini la fonction suivante qui est bien prouvé par Frama-c:Assertion sur pointeur sur un tableau
//ensures array <= \result < array+length && *\result == element;
/*@
requires 0 < length;
requires \valid_read(array + (0 .. length-1));
assigns \nothing;
behavior in:
assumes \exists int off ; 0 <= off < length && array[off] == element;
ensures *\result == element;
behavior notin:
assumes \forall int off ; 0 <= off < length ==> array[off] != element;
ensures \result == 0;
disjoint behaviors;
complete behaviors;
*/
int* search(int* array, int length, int element){
int *tmp;
/*@
loop invariant 0 <= i <= length;
loop invariant \forall int j; 0 <= j < i ==> array[j] != element;
loop assigns i;
loop variant length-i;
*/
for(int i = 0; i < length; i++)
{
if(array[i] == element)
{
tmp = &array[i];
//@ assert *tmp==element;
}
else
{
tmp = 0;
}
}
return tmp;
}
et je l'utilise dans la principale entrée suivante:
int main(){
int arr[5]={1,2,3,4,5};
int *p_arr;
p_arr = search(arr,5,4);
//@ assert *p_arr==30;
return 0
}
Je me demande pourquoi frama-c donne l'assertion "// @ assert * p_arr == 30;" comme vrai, je ne comprends pas.
Merci
Quelle version de frama-c? avec quelles options? qui dit que l'assertion est valide: WP? – Anne
Merci pour votre réponse, la version est phosphore, l'option est: frama-c-gui -wp -rte -val, la puce sur l'interface graphique est orange. Est-ce suffisant pour vous? –
Je dirais que la balle est verte à la ligne d'assertion, désolé –