Home Migration Guide Getting Started With Scripts Commands Examples
BracketHandlers

IFluidStack

Importing the class

It might be required for you to import the package if you encounter any issues (like casting an Array), so better be safe than sorry and add the import at the very top of the file.

script.zs
import crafttweaker.api.fluid.IFluidStack;

Implemented Interfaces

IFluidStack implements the following interfaces. That means all methods defined in these interfaces are also available in IFluidStack

Casters

Result typeIs Implicit
Result type
FluidIngredient
Is Implicit
true
Result type
MCFluid
Is Implicit
true

Methods

Return Type: IFluidStack

script.zs
// IFluidStack.asImmutable() as IFluidStack
myIFluidStack.asImmutable();

Checks if this IFluidStack, contains the given IFluidStack by checking if the fluids are the same, and if this fluid’s amount is bigger than the given fluid’s amount

Returns: true if this fluid contains the other fluid
Return Type: boolean

script.zs
IFluidStack.containsOther(other as IFluidStack) as boolean
ParameterTypeDescription
Parameter
other
Type
IFluidStack
Description
other IFluidStack to compare against

Copies the stack. Only needed when mutable stacks are involved.

Returns: A new stack, that contains the same info as this one
Return Type: IFluidStack

script.zs
// IFluidStack.copy() as IFluidStack
myIFluidStack.copy();

Returns the NBT tag attached to this FluidStack.

Returns: IData of the FluidStack’s NBT Tag, null if it doesn’t exist.
Return Type: IData

script.zs
// IFluidStack.getTag() as IData
myIFluidStack.getTag();

Return Type: boolean

script.zs
// IFluidStack.isImmutable() as boolean
myIFluidStack.isImmutable();

Makes this stack mutable

Returns: A new Stack, that is mutable.
Return Type: IFluidStack

script.zs
// IFluidStack.mutable() as IFluidStack
myIFluidStack.mutable();

Sets the fluid amount in MilliBuckets (mB)

Returns: A new stack, or this stack, depending if this stack is mutable
Return Type: IFluidStack

script.zs
// IFluidStack.setAmount(amount as int) as IFluidStack
myIFluidStack.setAmount(1000);
ParameterTypeDescription
Parameter
amount
Type
int
Description
The amount to multiply this stack

Sets the tag for the FluidStack.

Returns: This FluidStack if it is mutable, a new one with the changed property otherwise
Return Type: IFluidStack

script.zs
// IFluidStack.withTag(tag as IData) as IFluidStack
myIFluidStack.withTag({Display: {lore: ["Hello"]}});
ParameterTypeDescription
Parameter
tag
Type
IData
Description
The tag to set.

Operators

Checks if this IFluidStack, contains the given IFluidStack by checking if the fluids are the same, and if this fluid’s amount is bigger than the given fluid’s amount

script.zs
other as IFluidStack in myIFluidStack

Sets the fluid amount in MilliBuckets (MB)

script.zs
myIFluidStack * amount as int
myIFluidStack * 1000
script.zs
myIFluidStack | other as FluidIngredient

Properties

NameTypeHas GetterHas SetterDescription
Name
amount
Type
int
Has Getter
true
Has Setter
false
Description
Gets the fluid amount in MilliBuckets (mB).
Name
commandString
Type
string
Has Getter
true
Has Setter
false
Description
Returns the BEP to get this thingy
Name
empty
Type
boolean
Has Getter
true
Has Setter
false
Description
Gets whether or not this fluid stack is empty.
Name
fluid
Type
MCFluid
Has Getter
true
Has Setter
false
Description
Retrieves this fluid stack’s fluid.
Name
hasTag
Type
boolean
Has Getter
true
Has Setter
false
Description
Returns true if this FluidStack has a Tag
Name
isImmutable
Type
boolean
Has Getter
true
Has Setter
false
Description
No Description Provided
Name
registryName
Type
MCResourceLocation
Has Getter
true
Has Setter
false
Description
Gets the registry name for the fluid this stack is representing.
Name
tag
Type
IData
Has Getter
true
Has Setter
false
Description
Returns the NBT tag attached to this FluidStack.