Title: Typestate Checking
1Typestate Checking
Talk and extensive quotes taken from the
following papers 'Extending Typestate Checking
Using Conditional Liveness Analysis', Robert E.
Strom and Daniel M Yellin, 1993 'Typestae A
Programming Language Concept for Enhancing
Software Reliability', Robert E. Strom and Shaula
Yemini, 1986
2Topics covered - Definition and history of
typestate checking - Example Code and States -
Questions for discussion - Uses for typestate
checking - Changes in programming practices
3Typestate checking is 'a compile time program
analysis technique which enhances program
reliability by detecting type-correct
applications of operations which are non-sensical
in their current context' 'Strom and Yemini,
1986' 'a dataflow analysis technique for
verifying the operations performed on variables
obey the typestate rules of the
language'. 'Strom and Yellin, 1993
4The purpose of typestate checking is to -
ensure that programs performed their intended
operation. - security - design
assistance - eliminate 'non-sensical' programs,
which occur when an object is used illegally in
reference to its current state.
5Typestate checking mechanics
'To track typestate in a program at compile-time,
we make typestate a static invariant proerpty of
each variable name at each poin in the program
text. That is, if a variable name has a
particular typestate at a particular point the
program text, then the corresponding
execution-time data object will have that
typestate regardless of the path taken in the
program.' Strom and Yemini, 1986
6File handle Typestate Diagram
Uninitialized
Closed
Open
EOF
7Public static void main(String args)
Filehandle class_grades class_grades new
Filehandle('CS431') class_grades.open()
while(!class_grades.EOF()) Student_Obj
student student class_grades.read('Stephen
Torri') student.grade 'A'
class_grades.write('Stephen Torri', student)
class_grades.close()
8Start
Write('....')
Read('...')
Filehandle class_grades
Class_grades
EOF()
Open()
Exit
Close()
9Important Points about Coercions 'One important
benefit of typestate analysis is that it enables
the compiler to automatically insert storage
deallocation (finalization) code.' 'At the end
of the program, we require all initialized
variables to be finalized. We could enforce this
by run-time garbage collection. However, we can
also use typestate analysis to insert static
finalization when it can be statically determined
that a data structure is dead. The inserted
operations are called coercions' Strom and
Yellin, 1993
10Important Points about Coercions
(continued) 'Coercions give the run-time
environment the option of reclaiming memory
eagerly rather than performing periodic
reclamation.' 'Backwards dataflow analysis can
also be used to generate coercions. In fact,
using backward analysis, we sometimes finalize a
variable at an earlier point in the program
(thereby freeing storage sooner.' Strom and
Yellin, 1993
11Points to ponder
What kind of program languages lend themselves to
incorporating typestate checking?
12What kind of information do we expect the
programmer to provide? What part will we hide
in the compiler? How do you specify states in
the programming language?
13What some possible uses for typestate checking?
14Future work ideas of the authors - The framework
given is useful for checking program
correctness. - Optimizing compiles that make use
of liveness information. - To make typestate
checking practical for languages like C, stronger
analysis techniques must be used to handle
conditional initialization.
15That's All Folks! Picture courtesy of
www.warnerbros.com