001/* ---------------------------------------------------------------------------- 002 * This file was automatically generated by SWIG (https://www.swig.org). 003 * Version 4.1.1 004 * 005 * Do not make changes to this file unless you know what you are doing - modify 006 * the SWIG interface file instead. 007 * ----------------------------------------------------------------------------- */ 008 009package org.quantlib; 010 011public class FdmBoundaryCondition implements org.quantlib.helpers.QuantLibJNIHelpers.AutoCloseable { 012 private transient long swigCPtr; 013 private transient boolean swigCMemOwn; 014 015 protected FdmBoundaryCondition(long cPtr, boolean cMemoryOwn) { 016 swigCMemOwn = cMemoryOwn; 017 swigCPtr = cPtr; 018 } 019 020 protected static long getCPtr(FdmBoundaryCondition obj) { 021 return (obj == null) ? 0 : obj.swigCPtr; 022 } 023 024 protected void swigSetCMemOwn(boolean own) { 025 swigCMemOwn = own; 026 } 027 028 @SuppressWarnings("deprecation") 029 protected void finalize() { 030 delete(); 031 } 032 033 public synchronized void delete() { 034 if (swigCPtr != 0) { 035 if (swigCMemOwn) { 036 swigCMemOwn = false; 037 QuantLibJNI.delete_FdmBoundaryCondition(swigCPtr); 038 } 039 swigCPtr = 0; 040 } 041 } 042 043 public void applyBeforeApplying(FdmLinearOp arg0) { 044 QuantLibJNI.FdmBoundaryCondition_applyBeforeApplying(swigCPtr, this, FdmLinearOp.getCPtr(arg0), arg0); 045 } 046 047 public void applyAfterApplying(Array arg0) { 048 QuantLibJNI.FdmBoundaryCondition_applyAfterApplying(swigCPtr, this, Array.getCPtr(arg0), arg0); 049 } 050 051 public void applyBeforeSolving(FdmLinearOp arg0, Array rhs) { 052 QuantLibJNI.FdmBoundaryCondition_applyBeforeSolving(swigCPtr, this, FdmLinearOp.getCPtr(arg0), arg0, Array.getCPtr(rhs), rhs); 053 } 054 055 public void applyAfterSolving(Array arg0) { 056 QuantLibJNI.FdmBoundaryCondition_applyAfterSolving(swigCPtr, this, Array.getCPtr(arg0), arg0); 057 } 058 059 public void setTime(double t) { 060 QuantLibJNI.FdmBoundaryCondition_setTime(swigCPtr, this, t); 061 } 062 063 public final static class Side { 064 public final static FdmBoundaryCondition.Side NoSide = new FdmBoundaryCondition.Side("NoSide"); 065 public final static FdmBoundaryCondition.Side Upper = new FdmBoundaryCondition.Side("Upper"); 066 public final static FdmBoundaryCondition.Side Lower = new FdmBoundaryCondition.Side("Lower"); 067 068 public final int swigValue() { 069 return swigValue; 070 } 071 072 public String toString() { 073 return swigName; 074 } 075 076 public static Side swigToEnum(int swigValue) { 077 if (swigValue < swigValues.length && swigValue >= 0 && swigValues[swigValue].swigValue == swigValue) 078 return swigValues[swigValue]; 079 for (int i = 0; i < swigValues.length; i++) 080 if (swigValues[i].swigValue == swigValue) 081 return swigValues[i]; 082 throw new IllegalArgumentException("No enum " + Side.class + " with value " + swigValue); 083 } 084 085 private Side(String swigName) { 086 this.swigName = swigName; 087 this.swigValue = swigNext++; 088 } 089 090 private Side(String swigName, int swigValue) { 091 this.swigName = swigName; 092 this.swigValue = swigValue; 093 swigNext = swigValue+1; 094 } 095 096 private Side(String swigName, Side swigEnum) { 097 this.swigName = swigName; 098 this.swigValue = swigEnum.swigValue; 099 swigNext = this.swigValue+1; 100 } 101 102 private static Side[] swigValues = { NoSide, Upper, Lower }; 103 private static int swigNext = 0; 104 private final int swigValue; 105 private final String swigName; 106 } 107 108}