C# Class Jurassic.Compiler.ILGenerator

Represents a generator of CIL bytes.
Afficher le fichier Open project: paulbartrum/jurassic Class Usage Examples

Méthodes publiques

Méthode Description
Add ( ) : void

Pops two values from the stack, adds them together, then pushes the result to the stack.

BeginCatchBlock ( Type exceptionType ) : void

Begins a catch block. BeginExceptionBlock() must have already been called.

BeginExceptionBlock ( ) : void

Begins a try-catch-finally block. After issuing this instruction any following instructions are conceptually within the try block.

BeginFaultBlock ( ) : void

Begins a fault block. BeginExceptionBlock() must have already been called.

BeginFilterBlock ( ) : void

Begins a filter block. BeginExceptionBlock() must have already been called.

BeginFinallyBlock ( ) : void

Begins a finally block. BeginExceptionBlock() must have already been called.

BitwiseAnd ( ) : void

Pops two values from the stack, ANDs them together, then pushes the result to the stack.

BitwiseNot ( ) : void

Pops a value from the stack, inverts it, then pushes the result to the stack.

BitwiseOr ( ) : void

Pops two values from the stack, ORs them together, then pushes the result to the stack.

BitwiseXor ( ) : void

Pops two values from the stack, XORs them together, then pushes the result to the stack.

Box ( PrimitiveType type ) : void

Pops a value from the stack, converts it to an object reference, then pushes it back onto the stack.

Box ( Type type ) : void

Pops a value from the stack, converts it to an object reference, then pushes it back onto the stack.

Branch ( ILLabel label ) : void

Unconditionally branches to the given label.

BranchIfEqual ( ILLabel label ) : void

Branches to the given label if the two values on the top of the stack are equal.

BranchIfFalse ( ILLabel label ) : void

Branches to the given label if the value on the top of the stack is zero, false or null.

BranchIfGreaterThan ( ILLabel label ) : void

Branches to the given label if the first value on the stack is greater than the second value on the stack.

BranchIfGreaterThanOrEqual ( ILLabel label ) : void

Branches to the given label if the first value on the stack is greater than or equal to the second value on the stack.

BranchIfGreaterThanOrEqualUnsigned ( ILLabel label ) : void

Branches to the given label if the first value on the stack is greater than or equal to the second value on the stack. If the operands are integers then they are treated as if they are unsigned. If the operands are floating point numbers then a NaN value will trigger a branch.

BranchIfGreaterThanUnsigned ( ILLabel label ) : void

Branches to the given label if the first value on the stack is greater than the second value on the stack. If the operands are integers then they are treated as if they are unsigned. If the operands are floating point numbers then a NaN value will trigger a branch.

BranchIfLessThan ( ILLabel label ) : void

Branches to the given label if the first value on the stack is less than the second value on the stack.

BranchIfLessThanOrEqual ( ILLabel label ) : void

Branches to the given label if the first value on the stack is less than or equal to the second value on the stack.

BranchIfLessThanOrEqualUnsigned ( ILLabel label ) : void

Branches to the given label if the first value on the stack is less than or equal to the second value on the stack. If the operands are integers then they are treated as if they are unsigned. If the operands are floating point numbers then a NaN value will trigger a branch.

BranchIfLessThanUnsigned ( ILLabel label ) : void

Branches to the given label if the first value on the stack is less than the second value on the stack. If the operands are integers then they are treated as if they are unsigned. If the operands are floating point numbers then a NaN value will trigger a branch.

BranchIfNotEqual ( ILLabel label ) : void

Branches to the given label if the two values on the top of the stack are not equal.

BranchIfNotNull ( ILLabel label ) : void

Branches to the given label if the value on the top of the stack is non-zero, true or non-null.

BranchIfNotZero ( ILLabel label ) : void

Branches to the given label if the value on the top of the stack is non-zero, true or non-null.

BranchIfNull ( ILLabel label ) : void

Branches to the given label if the value on the top of the stack is zero, false or null.

BranchIfTrue ( ILLabel label ) : void

Branches to the given label if the value on the top of the stack is non-zero, true or non-null.

BranchIfZero ( ILLabel label ) : void

Branches to the given label if the value on the top of the stack is zero, false or null.

Breakpoint ( ) : void

Triggers a breakpoint in an attached debugger.

Call ( System method ) : void

Pops the method arguments off the stack, calls the given method, then pushes the result to the stack (if there was one). Identical to CallStatic() if the method is a static method (or is declared on a value type) or CallVirtual() otherwise.

CallStatic ( System method ) : void

Pops the method arguments off the stack, calls the given method, then pushes the result to the stack (if there was one). This operation can be used to call instance methods, but virtual overrides will not be called and a null check will not be performed at the callsite.

CallVirtual ( System method ) : void

Pops the method arguments off the stack, calls the given method, then pushes the result to the stack (if there was one). This operation cannot be used to call static methods. Virtual overrides are obeyed and a null check is performed.

CastClass ( Type type ) : void

Pops an object off the stack, checks that the object inherits from or implements the given type, and pushes the object onto the stack if the check was successful or throws an InvalidCastException if the check failed.

CompareEqual ( ) : void

Pops two values from the stack, compares, then pushes 1 if the first argument is equal to the second, or 0 otherwise. Produces 0 if one or both of the arguments are NaN.

CompareGreaterThan ( ) : void

Pops two values from the stack, compares, then pushes 1 if the first argument is greater than the second, or 0 otherwise. Produces 0 if one or both of the arguments are NaN.

CompareGreaterThanUnsigned ( ) : void

Pops two values from the stack, compares, then pushes 1 if the first argument is greater than the second, or 0 otherwise. Produces 1 if one or both of the arguments are NaN. Integers are considered to be unsigned.

CompareLessThan ( ) : void

Pops two values from the stack, compares, then pushes 1 if the first argument is less than the second, or 0 otherwise. Produces 0 if one or both of the arguments are NaN.

CompareLessThanUnsigned ( ) : void

Pops two values from the stack, compares, then pushes 1 if the first argument is less than the second, or 0 otherwise. Produces 1 if one or both of the arguments are NaN. Integers are considered to be unsigned.

Complete ( ) : void

Gets or sets a value which indicates whether diagnostics are enabled. Better error messages are provided in some cases if this property is set to true, however performance and memory usage are negatively impacted.

Emits a return statement and finalizes the generated code. Do not emit any more instructions after calling this method.

ConvertToDouble ( ) : void

Pops a value from the stack, converts it to a double, then pushes it back onto the stack.

ConvertToInt64 ( ) : void

Pops a value from the stack, converts it to a signed 64-bit integer, then pushes it back onto the stack.

ConvertToInteger ( ) : void

Pops a value from the stack, converts it to a signed integer, then pushes it back onto the stack.

ConvertToUnsignedInt64 ( ) : void

Pops a value from the stack, converts it to an unsigned 64-bit integer, then pushes it back onto the stack.

ConvertToUnsignedInteger ( ) : void

Pops a value from the stack, converts it to an unsigned integer, then pushes it back onto the stack.

ConvertUnsignedToDouble ( ) : void

Pops an unsigned integer from the stack, converts it to a double, then pushes it back onto the stack.

CreateLabel ( ) : ILLabel

Creates a label without setting its position.

CreateTemporaryVariable ( PrimitiveType type ) : ILLocalVariable

Retrieves a temporary variable with the given type, reusing a previous variable if possible.

CreateTemporaryVariable ( Type type ) : ILLocalVariable

Retrieves a temporary variable with the given type, reusing a previous variable if possible.

DeclareVariable ( PrimitiveType type, string name = null ) : ILLocalVariable

Declares a new local variable.

DeclareVariable ( Type type, string name = null ) : ILLocalVariable

Declares a new local variable.

DefineLabelPosition ( ) : ILLabel

Creates a label and sets its position.

DefineLabelPosition ( ILLabel label ) : void

Defines the position of the given label.

Divide ( ) : void

Pops two values from the stack, divides the first by the second, then pushes the result to the stack.

Duplicate ( ) : void

Duplicates the value on the top of the stack.

EndExceptionBlock ( ) : void

Ends a try-catch-finally block.

EndFault ( ) : void

This instruction can be used from within a fault block to resume the exception handling process. It is the only valid way of leaving a fault block.

EndFilter ( ) : void

This instruction can be used from within a filter block to indicate whether the exception will be handled. It pops an integer from the stack which should be 0 to continue searching for an exception handler or 1 to use the handler associated with the filter. EndFilter() must be called at the end of a filter block.

EndFinally ( ) : void

This instruction can be used from within a finally block to resume the exception handling process. It is the only valid way of leaving a finally block.

InitObject ( Type type ) : void

Pops a managed or native pointer off the stack and initializes the referenced type with zeros.

IsInstance ( Type type ) : void

Pops an object off the stack, checks that the object inherits from or implements the given type, and pushes either the object (if the check was successful) or null (if the check failed) onto the stack.

Leave ( ILLabel label ) : void

Unconditionally branches to the given label. Unlike the regular branch instruction, this instruction can exit out of try, filter and catch blocks.

LoadAddressOfVariable ( ILLocalVariable variable ) : void

Pushes the address of the given variable onto the stack.

LoadArgument ( int argumentIndex ) : void

Pushes the value of the method argument with the given index onto the stack.

LoadArrayElement ( PrimitiveType type ) : void

Pops the array and index off the stack and pushes the element value onto the stack.

LoadArrayElement ( Type type ) : void

Pops the array and index off the stack and pushes the element value onto the stack.

LoadArrayLength ( ) : void

Pops an array off the stack and pushes the length of the array onto the stack.

LoadBoolean ( bool value ) : void

Pushes a constant value onto the stack.

LoadDouble ( double value ) : void

Pushes a constant value onto the stack.

LoadField ( System field ) : void

Pushes the value of the given field onto the stack.

LoadInt32 ( int value ) : void

Pushes a constant value onto the stack.

LoadInt32 ( uint value ) : void

Pushes an unsigned constant value onto the stack.

LoadInt64 ( long value ) : void

Pushes a 64-bit constant value onto the stack.

LoadInt64 ( ulong value ) : void

Pushes an unsigned 64-bit constant value onto the stack.

LoadMethodPointer ( System method ) : void

Pushes a pointer to the native code implementing the given method onto the evaluation stack. This method is identical to LoadStaticMethodPointer() if the method is a static method (or is declared on a value type) or LoadVirtualMethodPointer() otherwise.

LoadNull ( ) : void

Pushes null onto the stack.

LoadStaticMethodPointer ( System method ) : void

Pushes a pointer to the native code implementing the given method onto the evaluation stack. The virtual qualifier will be ignored, if present.

LoadString ( string value ) : void

Pushes a constant value onto the stack.

LoadStringOrNull ( string value ) : void

Pushes a constant value onto the stack.

LoadToken ( System method ) : void

Pushes a RuntimeMethodHandle corresponding to the given method onto the evaluation stack.

LoadToken ( Type type ) : void

Pushes a RuntimeTypeHandle corresponding to the given type onto the evaluation stack.

LoadVariable ( ILLocalVariable variable ) : void

Pushes the value of the given variable onto the stack.

LoadVirtualMethodPointer ( System method ) : void

Pushes a pointer to the native code implementing the given method onto the evaluation stack. This method cannot be used to retrieve a pointer to a static method.

MarkSequencePoint ( System document, Jurassic.Compiler.SourceCodeSpan span ) : void

Marks a sequence point in the Microsoft intermediate language (MSIL) stream.

MarkSequencePoint ( System document, int startLine, int startColumn, int endLine, int endColumn ) : void

Marks a sequence point in the Microsoft intermediate language (MSIL) stream.

Multiply ( ) : void

Pops two values from the stack, multiplies them together, then pushes the result to the stack.

Negate ( ) : void

Pops a value from the stack, negates it, then pushes it back onto the stack.

NewArray ( Type type ) : void

Pops the size of the array off the stack and pushes a new array of the given type onto the stack.

NewObject ( System constructor ) : void

Pops the constructor arguments off the stack and creates a new instance of the object.

NoOperation ( ) : void

Does nothing.

Pop ( ) : void

Pops the value from the top of the stack.

ReleaseTemporaryVariable ( ILLocalVariable temporaryVariable ) : void

Indicates that the given temporary variable is no longer needed.

Remainder ( ) : void

Pops two values from the stack, divides the first by the second, then pushes the remainder to the stack.

Return ( ) : void

Returns from the current method. A value is popped from the stack and used as the return value.

ShiftLeft ( ) : void

Pops two values from the stack, shifts the first to the left, then pushes the result to the stack.

ShiftRight ( ) : void

Pops two values from the stack, shifts the first to the right, then pushes the result to the stack. The sign bit is preserved.

ShiftRightUnsigned ( ) : void

Pops two values from the stack, shifts the first to the right, then pushes the result to the stack. The sign bit is not preserved.

StoreArgument ( int argumentIndex ) : void

Pops a value from the stack and stores it in the method argument with the given index.

StoreArrayElement ( PrimitiveType type ) : void

Pops the array, index and value off the stack and stores the value in the array.

StoreArrayElement ( Type type ) : void

Pops the array, index and value off the stack and stores the value in the array.

StoreField ( System field ) : void

Pops a value off the stack and stores it in the given field.

StoreVariable ( ILLocalVariable variable ) : void

Pops the value from the top of the stack and stores it in the given local variable.

Subtract ( ) : void

Pops two values from the stack, subtracts the second from the first, then pushes the result to the stack.

Switch ( ILLabel labels ) : void

Creates a jump table. A value is popped from the stack - this value indicates the index of the label in the labels array to jump to.

Throw ( ) : void

Pops an exception object off the stack and throws the exception.

Unbox ( PrimitiveType type ) : void

Pops an object reference (representing a boxed value) from the stack, extracts the address, then pushes that address onto the stack.

Unbox ( Type type ) : void

Pops an object reference (representing a boxed value) from the stack, extracts the address, then pushes that address onto the stack.

UnboxAny ( PrimitiveType type ) : void

Pops an object reference (representing a boxed value) from the stack, extracts the value, then pushes the value onto the stack.

UnboxAny ( Type type ) : void

Pops an object reference (representing a boxed value) from the stack, extracts the value, then pushes the value onto the stack.

Method Details

Add() public abstract méthode

Pops two values from the stack, adds them together, then pushes the result to the stack.
public abstract Add ( ) : void
Résultat void

BeginCatchBlock() public abstract méthode

Begins a catch block. BeginExceptionBlock() must have already been called.
public abstract BeginCatchBlock ( Type exceptionType ) : void
exceptionType System.Type The type of exception to handle.
Résultat void

BeginExceptionBlock() public abstract méthode

Begins a try-catch-finally block. After issuing this instruction any following instructions are conceptually within the try block.
public abstract BeginExceptionBlock ( ) : void
Résultat void

BeginFaultBlock() public abstract méthode

Begins a fault block. BeginExceptionBlock() must have already been called.
public abstract BeginFaultBlock ( ) : void
Résultat void

BeginFilterBlock() public abstract méthode

Begins a filter block. BeginExceptionBlock() must have already been called.
public abstract BeginFilterBlock ( ) : void
Résultat void

BeginFinallyBlock() public abstract méthode

Begins a finally block. BeginExceptionBlock() must have already been called.
public abstract BeginFinallyBlock ( ) : void
Résultat void

BitwiseAnd() public abstract méthode

Pops two values from the stack, ANDs them together, then pushes the result to the stack.
public abstract BitwiseAnd ( ) : void
Résultat void

BitwiseNot() public abstract méthode

Pops a value from the stack, inverts it, then pushes the result to the stack.
public abstract BitwiseNot ( ) : void
Résultat void

BitwiseOr() public abstract méthode

Pops two values from the stack, ORs them together, then pushes the result to the stack.
public abstract BitwiseOr ( ) : void
Résultat void

BitwiseXor() public abstract méthode

Pops two values from the stack, XORs them together, then pushes the result to the stack.
public abstract BitwiseXor ( ) : void
Résultat void

Box() public méthode

Pops a value from the stack, converts it to an object reference, then pushes it back onto the stack.
public Box ( PrimitiveType type ) : void
type PrimitiveType The type of value to box. This should be a value type.
Résultat void

Box() public abstract méthode

Pops a value from the stack, converts it to an object reference, then pushes it back onto the stack.
public abstract Box ( Type type ) : void
type System.Type The type of value to box. This should be a value type.
Résultat void

Branch() public abstract méthode

Unconditionally branches to the given label.
public abstract Branch ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfEqual() public abstract méthode

Branches to the given label if the two values on the top of the stack are equal.
public abstract BranchIfEqual ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfFalse() public méthode

Branches to the given label if the value on the top of the stack is zero, false or null.
public BranchIfFalse ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfGreaterThan() public abstract méthode

Branches to the given label if the first value on the stack is greater than the second value on the stack.
public abstract BranchIfGreaterThan ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfGreaterThanOrEqual() public abstract méthode

Branches to the given label if the first value on the stack is greater than or equal to the second value on the stack.
public abstract BranchIfGreaterThanOrEqual ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfGreaterThanOrEqualUnsigned() public abstract méthode

Branches to the given label if the first value on the stack is greater than or equal to the second value on the stack. If the operands are integers then they are treated as if they are unsigned. If the operands are floating point numbers then a NaN value will trigger a branch.
public abstract BranchIfGreaterThanOrEqualUnsigned ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfGreaterThanUnsigned() public abstract méthode

Branches to the given label if the first value on the stack is greater than the second value on the stack. If the operands are integers then they are treated as if they are unsigned. If the operands are floating point numbers then a NaN value will trigger a branch.
public abstract BranchIfGreaterThanUnsigned ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfLessThan() public abstract méthode

Branches to the given label if the first value on the stack is less than the second value on the stack.
public abstract BranchIfLessThan ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfLessThanOrEqual() public abstract méthode

Branches to the given label if the first value on the stack is less than or equal to the second value on the stack.
public abstract BranchIfLessThanOrEqual ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfLessThanOrEqualUnsigned() public abstract méthode

Branches to the given label if the first value on the stack is less than or equal to the second value on the stack. If the operands are integers then they are treated as if they are unsigned. If the operands are floating point numbers then a NaN value will trigger a branch.
public abstract BranchIfLessThanOrEqualUnsigned ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfLessThanUnsigned() public abstract méthode

Branches to the given label if the first value on the stack is less than the second value on the stack. If the operands are integers then they are treated as if they are unsigned. If the operands are floating point numbers then a NaN value will trigger a branch.
public abstract BranchIfLessThanUnsigned ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfNotEqual() public abstract méthode

Branches to the given label if the two values on the top of the stack are not equal.
public abstract BranchIfNotEqual ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfNotNull() public méthode

Branches to the given label if the value on the top of the stack is non-zero, true or non-null.
public BranchIfNotNull ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfNotZero() public abstract méthode

Branches to the given label if the value on the top of the stack is non-zero, true or non-null.
public abstract BranchIfNotZero ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfNull() public méthode

Branches to the given label if the value on the top of the stack is zero, false or null.
public BranchIfNull ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfTrue() public méthode

Branches to the given label if the value on the top of the stack is non-zero, true or non-null.
public BranchIfTrue ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

BranchIfZero() public abstract méthode

Branches to the given label if the value on the top of the stack is zero, false or null.
public abstract BranchIfZero ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

Breakpoint() public abstract méthode

Triggers a breakpoint in an attached debugger.
public abstract Breakpoint ( ) : void
Résultat void

Call() public méthode

Pops the method arguments off the stack, calls the given method, then pushes the result to the stack (if there was one). Identical to CallStatic() if the method is a static method (or is declared on a value type) or CallVirtual() otherwise.
public Call ( System method ) : void
method System The method to call.
Résultat void

CallStatic() public abstract méthode

Pops the method arguments off the stack, calls the given method, then pushes the result to the stack (if there was one). This operation can be used to call instance methods, but virtual overrides will not be called and a null check will not be performed at the callsite.
public abstract CallStatic ( System method ) : void
method System The method to call.
Résultat void

CallVirtual() public abstract méthode

Pops the method arguments off the stack, calls the given method, then pushes the result to the stack (if there was one). This operation cannot be used to call static methods. Virtual overrides are obeyed and a null check is performed.
The method is static.
public abstract CallVirtual ( System method ) : void
method System The method to call.
Résultat void

CastClass() public abstract méthode

Pops an object off the stack, checks that the object inherits from or implements the given type, and pushes the object onto the stack if the check was successful or throws an InvalidCastException if the check failed.
public abstract CastClass ( Type type ) : void
type System.Type The type of the class the object inherits from or the interface the /// object implements.
Résultat void

CompareEqual() public abstract méthode

Pops two values from the stack, compares, then pushes 1 if the first argument is equal to the second, or 0 otherwise. Produces 0 if one or both of the arguments are NaN.
public abstract CompareEqual ( ) : void
Résultat void

CompareGreaterThan() public abstract méthode

Pops two values from the stack, compares, then pushes 1 if the first argument is greater than the second, or 0 otherwise. Produces 0 if one or both of the arguments are NaN.
public abstract CompareGreaterThan ( ) : void
Résultat void

CompareGreaterThanUnsigned() public abstract méthode

Pops two values from the stack, compares, then pushes 1 if the first argument is greater than the second, or 0 otherwise. Produces 1 if one or both of the arguments are NaN. Integers are considered to be unsigned.
public abstract CompareGreaterThanUnsigned ( ) : void
Résultat void

CompareLessThan() public abstract méthode

Pops two values from the stack, compares, then pushes 1 if the first argument is less than the second, or 0 otherwise. Produces 0 if one or both of the arguments are NaN.
public abstract CompareLessThan ( ) : void
Résultat void

CompareLessThanUnsigned() public abstract méthode

Pops two values from the stack, compares, then pushes 1 if the first argument is less than the second, or 0 otherwise. Produces 1 if one or both of the arguments are NaN. Integers are considered to be unsigned.
public abstract CompareLessThanUnsigned ( ) : void
Résultat void

Complete() public abstract méthode

Gets or sets a value which indicates whether diagnostics are enabled. Better error messages are provided in some cases if this property is set to true, however performance and memory usage are negatively impacted. Emits a return statement and finalizes the generated code. Do not emit any more instructions after calling this method.
public abstract Complete ( ) : void
Résultat void

ConvertToDouble() public abstract méthode

Pops a value from the stack, converts it to a double, then pushes it back onto the stack.
public abstract ConvertToDouble ( ) : void
Résultat void

ConvertToInt64() public abstract méthode

Pops a value from the stack, converts it to a signed 64-bit integer, then pushes it back onto the stack.
public abstract ConvertToInt64 ( ) : void
Résultat void

ConvertToInteger() public abstract méthode

Pops a value from the stack, converts it to a signed integer, then pushes it back onto the stack.
public abstract ConvertToInteger ( ) : void
Résultat void

ConvertToUnsignedInt64() public abstract méthode

Pops a value from the stack, converts it to an unsigned 64-bit integer, then pushes it back onto the stack.
public abstract ConvertToUnsignedInt64 ( ) : void
Résultat void

ConvertToUnsignedInteger() public abstract méthode

Pops a value from the stack, converts it to an unsigned integer, then pushes it back onto the stack.
public abstract ConvertToUnsignedInteger ( ) : void
Résultat void

ConvertUnsignedToDouble() public abstract méthode

Pops an unsigned integer from the stack, converts it to a double, then pushes it back onto the stack.
public abstract ConvertUnsignedToDouble ( ) : void
Résultat void

CreateLabel() public abstract méthode

Creates a label without setting its position.
public abstract CreateLabel ( ) : ILLabel
Résultat ILLabel

CreateTemporaryVariable() public méthode

Retrieves a temporary variable with the given type, reusing a previous variable if possible.
public CreateTemporaryVariable ( PrimitiveType type ) : ILLocalVariable
type PrimitiveType The type of variable to create.
Résultat ILLocalVariable

CreateTemporaryVariable() public méthode

Retrieves a temporary variable with the given type, reusing a previous variable if possible.
public CreateTemporaryVariable ( Type type ) : ILLocalVariable
type System.Type The type of variable to create.
Résultat ILLocalVariable

DeclareVariable() public méthode

Declares a new local variable.
public DeclareVariable ( PrimitiveType type, string name = null ) : ILLocalVariable
type PrimitiveType The type of the local variable.
name string The name of the local variable. Can be null.
Résultat ILLocalVariable

DeclareVariable() public abstract méthode

Declares a new local variable.
public abstract DeclareVariable ( Type type, string name = null ) : ILLocalVariable
type System.Type The type of the local variable.
name string The name of the local variable. Can be null.
Résultat ILLocalVariable

DefineLabelPosition() public méthode

Creates a label and sets its position.
public DefineLabelPosition ( ) : ILLabel
Résultat ILLabel

DefineLabelPosition() public abstract méthode

Defines the position of the given label.
public abstract DefineLabelPosition ( ILLabel label ) : void
label ILLabel The label to define.
Résultat void

Divide() public abstract méthode

Pops two values from the stack, divides the first by the second, then pushes the result to the stack.
public abstract Divide ( ) : void
Résultat void

Duplicate() public abstract méthode

Duplicates the value on the top of the stack.
public abstract Duplicate ( ) : void
Résultat void

EndExceptionBlock() public abstract méthode

Ends a try-catch-finally block.
public abstract EndExceptionBlock ( ) : void
Résultat void

EndFault() public méthode

This instruction can be used from within a fault block to resume the exception handling process. It is the only valid way of leaving a fault block.
public EndFault ( ) : void
Résultat void

EndFilter() public abstract méthode

This instruction can be used from within a filter block to indicate whether the exception will be handled. It pops an integer from the stack which should be 0 to continue searching for an exception handler or 1 to use the handler associated with the filter. EndFilter() must be called at the end of a filter block.
public abstract EndFilter ( ) : void
Résultat void

EndFinally() public abstract méthode

This instruction can be used from within a finally block to resume the exception handling process. It is the only valid way of leaving a finally block.
public abstract EndFinally ( ) : void
Résultat void

InitObject() public abstract méthode

Pops a managed or native pointer off the stack and initializes the referenced type with zeros.
public abstract InitObject ( Type type ) : void
type System.Type The type the pointer on the top of the stack is pointing to.
Résultat void

IsInstance() public abstract méthode

Pops an object off the stack, checks that the object inherits from or implements the given type, and pushes either the object (if the check was successful) or null (if the check failed) onto the stack.
public abstract IsInstance ( Type type ) : void
type System.Type The type of the class the object inherits from or the interface the /// object implements.
Résultat void

Leave() public abstract méthode

Unconditionally branches to the given label. Unlike the regular branch instruction, this instruction can exit out of try, filter and catch blocks.
public abstract Leave ( ILLabel label ) : void
label ILLabel The label to branch to.
Résultat void

LoadAddressOfVariable() public abstract méthode

Pushes the address of the given variable onto the stack.
public abstract LoadAddressOfVariable ( ILLocalVariable variable ) : void
variable ILLocalVariable The variable whose address will be pushed.
Résultat void

LoadArgument() public abstract méthode

Pushes the value of the method argument with the given index onto the stack.
public abstract LoadArgument ( int argumentIndex ) : void
argumentIndex int The index of the argument to push onto the stack.
Résultat void

LoadArrayElement() public méthode

Pops the array and index off the stack and pushes the element value onto the stack.
public LoadArrayElement ( PrimitiveType type ) : void
type PrimitiveType The element type.
Résultat void

LoadArrayElement() public abstract méthode

Pops the array and index off the stack and pushes the element value onto the stack.
public abstract LoadArrayElement ( Type type ) : void
type System.Type The element type.
Résultat void

LoadArrayLength() public abstract méthode

Pops an array off the stack and pushes the length of the array onto the stack.
public abstract LoadArrayLength ( ) : void
Résultat void

LoadBoolean() public méthode

Pushes a constant value onto the stack.
public LoadBoolean ( bool value ) : void
value bool The boolean to push onto the stack.
Résultat void

LoadDouble() public abstract méthode

Pushes a constant value onto the stack.
public abstract LoadDouble ( double value ) : void
value double The number to push onto the stack.
Résultat void

LoadField() public abstract méthode

Pushes the value of the given field onto the stack.
public abstract LoadField ( System field ) : void
field System The field whose value will be pushed.
Résultat void

LoadInt32() public abstract méthode

Pushes a constant value onto the stack.
public abstract LoadInt32 ( int value ) : void
value int The integer to push onto the stack.
Résultat void

LoadInt32() public méthode

Pushes an unsigned constant value onto the stack.
public LoadInt32 ( uint value ) : void
value uint The integer to push onto the stack.
Résultat void

LoadInt64() public abstract méthode

Pushes a 64-bit constant value onto the stack.
public abstract LoadInt64 ( long value ) : void
value long The 64-bit integer to push onto the stack.
Résultat void

LoadInt64() public méthode

Pushes an unsigned 64-bit constant value onto the stack.
public LoadInt64 ( ulong value ) : void
value ulong The 64-bit integer to push onto the stack.
Résultat void

LoadMethodPointer() public méthode

Pushes a pointer to the native code implementing the given method onto the evaluation stack. This method is identical to LoadStaticMethodPointer() if the method is a static method (or is declared on a value type) or LoadVirtualMethodPointer() otherwise.
public LoadMethodPointer ( System method ) : void
method System The method to retrieve a pointer for.
Résultat void

LoadNull() public abstract méthode

Pushes null onto the stack.
public abstract LoadNull ( ) : void
Résultat void

LoadStaticMethodPointer() public abstract méthode

Pushes a pointer to the native code implementing the given method onto the evaluation stack. The virtual qualifier will be ignored, if present.
public abstract LoadStaticMethodPointer ( System method ) : void
method System The method to retrieve a pointer for.
Résultat void

LoadString() public abstract méthode

Pushes a constant value onto the stack.
public abstract LoadString ( string value ) : void
value string The string to push onto the stack.
Résultat void

LoadStringOrNull() public méthode

Pushes a constant value onto the stack.
public LoadStringOrNull ( string value ) : void
value string The string to push onto the stack. Can be null.
Résultat void

LoadToken() public abstract méthode

Pushes a RuntimeMethodHandle corresponding to the given method onto the evaluation stack.
public abstract LoadToken ( System method ) : void
method System The method to convert to a RuntimeMethodHandle.
Résultat void

LoadToken() public abstract méthode

Pushes a RuntimeTypeHandle corresponding to the given type onto the evaluation stack.
public abstract LoadToken ( Type type ) : void
type System.Type The type to convert to a RuntimeTypeHandle.
Résultat void

LoadVariable() public abstract méthode

Pushes the value of the given variable onto the stack.
public abstract LoadVariable ( ILLocalVariable variable ) : void
variable ILLocalVariable The variable whose value will be pushed.
Résultat void

LoadVirtualMethodPointer() public abstract méthode

Pushes a pointer to the native code implementing the given method onto the evaluation stack. This method cannot be used to retrieve a pointer to a static method.
The method is static.
public abstract LoadVirtualMethodPointer ( System method ) : void
method System The method to retrieve a pointer for.
Résultat void

MarkSequencePoint() public méthode

Marks a sequence point in the Microsoft intermediate language (MSIL) stream.
public MarkSequencePoint ( System document, Jurassic.Compiler.SourceCodeSpan span ) : void
document System The document for which the sequence point is being defined.
span Jurassic.Compiler.SourceCodeSpan The start and end positions which define the sequence point.
Résultat void

MarkSequencePoint() public abstract méthode

Marks a sequence point in the Microsoft intermediate language (MSIL) stream.
public abstract MarkSequencePoint ( System document, int startLine, int startColumn, int endLine, int endColumn ) : void
document System The document for which the sequence point is being defined.
startLine int The line where the sequence point begins.
startColumn int The column in the line where the sequence point begins.
endLine int The line where the sequence point ends.
endColumn int The column in the line where the sequence point ends.
Résultat void

Multiply() public abstract méthode

Pops two values from the stack, multiplies them together, then pushes the result to the stack.
public abstract Multiply ( ) : void
Résultat void

Negate() public abstract méthode

Pops a value from the stack, negates it, then pushes it back onto the stack.
public abstract Negate ( ) : void
Résultat void

NewArray() public abstract méthode

Pops the size of the array off the stack and pushes a new array of the given type onto the stack.
public abstract NewArray ( Type type ) : void
type System.Type The element type.
Résultat void

NewObject() public abstract méthode

Pops the constructor arguments off the stack and creates a new instance of the object.
public abstract NewObject ( System constructor ) : void
constructor System The constructor that is used to initialize the object.
Résultat void

NoOperation() public abstract méthode

Does nothing.
public abstract NoOperation ( ) : void
Résultat void

Pop() public abstract méthode

Pops the value from the top of the stack.
public abstract Pop ( ) : void
Résultat void

ReleaseTemporaryVariable() public méthode

Indicates that the given temporary variable is no longer needed.
public ReleaseTemporaryVariable ( ILLocalVariable temporaryVariable ) : void
temporaryVariable ILLocalVariable The temporary variable created using CreateTemporaryVariable().
Résultat void

Remainder() public abstract méthode

Pops two values from the stack, divides the first by the second, then pushes the remainder to the stack.
public abstract Remainder ( ) : void
Résultat void

Return() public abstract méthode

Returns from the current method. A value is popped from the stack and used as the return value.
public abstract Return ( ) : void
Résultat void

ShiftLeft() public abstract méthode

Pops two values from the stack, shifts the first to the left, then pushes the result to the stack.
public abstract ShiftLeft ( ) : void
Résultat void

ShiftRight() public abstract méthode

Pops two values from the stack, shifts the first to the right, then pushes the result to the stack. The sign bit is preserved.
public abstract ShiftRight ( ) : void
Résultat void

ShiftRightUnsigned() public abstract méthode

Pops two values from the stack, shifts the first to the right, then pushes the result to the stack. The sign bit is not preserved.
public abstract ShiftRightUnsigned ( ) : void
Résultat void

StoreArgument() public abstract méthode

Pops a value from the stack and stores it in the method argument with the given index.
public abstract StoreArgument ( int argumentIndex ) : void
argumentIndex int The index of the argument to store into.
Résultat void

StoreArrayElement() public méthode

Pops the array, index and value off the stack and stores the value in the array.
public StoreArrayElement ( PrimitiveType type ) : void
type PrimitiveType The element type.
Résultat void

StoreArrayElement() public abstract méthode

Pops the array, index and value off the stack and stores the value in the array.
public abstract StoreArrayElement ( Type type ) : void
type System.Type The element type.
Résultat void

StoreField() public abstract méthode

Pops a value off the stack and stores it in the given field.
public abstract StoreField ( System field ) : void
field System The field to modify.
Résultat void

StoreVariable() public abstract méthode

Pops the value from the top of the stack and stores it in the given local variable.
public abstract StoreVariable ( ILLocalVariable variable ) : void
variable ILLocalVariable The variable to store the value.
Résultat void

Subtract() public abstract méthode

Pops two values from the stack, subtracts the second from the first, then pushes the result to the stack.
public abstract Subtract ( ) : void
Résultat void

Switch() public abstract méthode

Creates a jump table. A value is popped from the stack - this value indicates the index of the label in the labels array to jump to.
public abstract Switch ( ILLabel labels ) : void
labels ILLabel A array of labels.
Résultat void

Throw() public abstract méthode

Pops an exception object off the stack and throws the exception.
public abstract Throw ( ) : void
Résultat void

Unbox() public méthode

Pops an object reference (representing a boxed value) from the stack, extracts the address, then pushes that address onto the stack.
public Unbox ( PrimitiveType type ) : void
type PrimitiveType The type of the boxed value. This should be a value type.
Résultat void

Unbox() public abstract méthode

Pops an object reference (representing a boxed value) from the stack, extracts the address, then pushes that address onto the stack.
public abstract Unbox ( Type type ) : void
type System.Type The type of the boxed value. This should be a value type.
Résultat void

UnboxAny() public méthode

Pops an object reference (representing a boxed value) from the stack, extracts the value, then pushes the value onto the stack.
public UnboxAny ( PrimitiveType type ) : void
type PrimitiveType The type of the boxed value. This should be a value type.
Résultat void

UnboxAny() public abstract méthode

Pops an object reference (representing a boxed value) from the stack, extracts the value, then pushes the value onto the stack.
public abstract UnboxAny ( Type type ) : void
type System.Type The type of the boxed value. This should be a value type.
Résultat void