Mavryk_raw_protocol_alpha.Script_tc_contextThis module defines the typechecking context used during the translation from Michelson untyped nodes to typed nodes (Script_ir_translator). The context keeps track of the origin of the code (top-level from a contract, in a view, etc.), plus some information to allow or forbid instructions given the context (no `SELF` in a lambda for example).
Lambdas are a bit special when considering stateful instructions such as TRANSFER_TOKENS. For instance, a view containing a TRANSFER_TOKENS is not OK, because calling the view would transfer tokens from the view's owner. However, a view returning a lambda containing a TRANSFER_TOKENS could be considered OK, as the decision whether to execute it or not falls on the view's caller, whose tokens would be transfered. This type is used to keep track of whether we are inside a lambda: it is true when inside a lambda, and false otherwise.
type callsite = | Toplevel : {storage_type : ('sto, _) Script_typed_ir.ty;param_type : ('param, _) Script_typed_ir.ty;entrypoints : 'param Script_typed_ir.entrypoints;} -> callsite| View : callsite| Data : callsiteThe calling context when parsing Michelson code: either a top-level contract code, the code of a view, or code in data (when pushing a block of instructions for example).
val toplevel : 
  storage_type:('sto, _) Script_typed_ir.ty ->
  param_type:('param, _) Script_typed_ir.ty ->
  entrypoints:'param Script_typed_ir.entrypoints ->
  tval view : tval data : tThis value can be used outside the translation module as a simple context when testing code, for example.
val is_in_lambda : t -> boolval check_not_in_view : 
  Alpha_context.Script.location ->
  legacy:bool ->
  t ->
  Alpha_context.Script.prim ->
  unit Mavryk_protocol_environment_alpha.Error_monad.tzresult