BlockEnums.jl
BlockEnums
BlockEnums
— Modulemodule BlockEnums
BlockEnums
is a package (and module) providing the type BlockEnum
. Concrete subtypes are created with the @blockenum
macro, which is similar to Enums.@enum
.
BlockEnums.BlockEnum
— TypeBlockEnum{T<:Integer}
The abstract supertype of all enumerated types defined with @blockenum
.
Create a new BlockEnum
with the macro @blockenum
.
BlockEnums.@blockenum
— Macro@blockenum EnumName[::BaseType] value1[=x] value2[=y]
@blockenum (EnumName[::BaseType], [keyword=val,...]) [value1, value2,...]
Create a BlockEnum{BaseType}
subtype with name EnumName
and enum member values of value1
and value2
with optional assigned values of x
and y
, respectively.
Keywords
mod=Modname
–EnumName
and its instances will be namespaced in a moduleModname
, which will be created.blocklength=n
–n
is a literalInt
. The common length of each "block" of enums.numblocks=m
–m
is a literalInt
. The intial number of blocks to create.compactshow
– a literalBool
. Iftrue
, then do not print the equivalentBaseType
value of instances.
EnumName
can be used just like other types and enum member values as regular values, such as
Examples
julia> @blockenum Fruit apple=1 orange=2 kiwi=3
julia> f(x::Fruit) = "I'm a Fruit with value: $(Int(x))"
f (generic function with 1 method)
julia> f(apple)
"I'm a Fruit with value: 1"
julia> Fruit(1)
apple::Fruit = 1
Add more instances like this
julia> @add Fruit banana lemon
Values can also be specified inside a begin
block, e.g.
@blockenum EnumName begin
value1
value2
end
BaseType
, which defaults to Int32
, must be a primitive subtype of Integer
. Member values can be converted between the enum type and BaseType
. read
and write
perform these conversions automatically. In case the enum is created with a non-default BaseType
, Integer(value1)
will return the integer value1
with the type BaseType
.
To list all the instances of an enum use instances
, e.g.
julia> instances(Fruit)
(apple, orange, kiwi, banana, lemon)
It is possible to construct a symbol from an enum instance:
julia> Symbol(apple)
:apple
Examples of adding instances to blocks.
julia> using BlockEnums
julia> @blockenum (Myenum, mod=MyenumMod, blocklength=100, numblocks=10, compactshow=false)
julia> @addinblock Myenum 1 a b c
c::Myenum = 3
julia> @addinblock Myenum 3 x y z
z::Myenum = 203
julia> BlockEnums.blockindex(MyenumMod.y)
3
See @add
, @addinblock
These functions retrieve information on BlockEnum
s.
BlockEnums.namemap
— Functionnamemap(::Type{<:BlockEnum})
Return the Dict
mapping all values to name symbols.
This is not a method of of the function of the same name with methods defined on Base.Enum
. Rather it is a function in the BlockEnums
module. Perhaps this should not be advertized or exposed.
BlockEnums.basetype
— Functionbasetype(V::Type{<:BlockEnum{T}})
Return T
, which is the bitstype whose values are bitcast to the type V
. This is the type of the value returned by Integer(x::V)
. The type is in a sense the underlying type of V
.
BlockEnums.val
— Functionval(x::BlockEnum{T})
Return x
bitcast to type T
.
BlockEnums.getmodule
— Functiongetmodule(t::Type{<:BlockEnum})
Get the module in which t
is defined.
BlockEnums.compact_show
— Functioncompact_show(t::Type{<:BlockEnum})
Return true
if compact show was set when t
was defined. This omits printing the corresponding integer when printing. To enable compact show, include the key/val pair compactshow=true
when defining t
.
Base.instances
— Methodinstances(t::Type{<:BlockEnum})
Return a Tuple
of all of the named values of t
.
Base.length
— Methodlength(T::Type{<:BlockEnum})
Return the number of instances of type T
.
A few functions and macros pertain to the blocks feature.
BlockEnums.addblocks!
— Functionaddblocks!(t::Type{<:BlockEnum}), nblocks::Integer)
Add and initialize nblocks
blocks to the bookkeeping for t
. The number of active blocks for the type is returned.
BlockEnums.maxvalind
— Functionmaxvalind(t::Type{<:BlockEnum}, block_num::Integer)
Return the largest index for which a name has been assigned in the block_num
th block t
. This number is constrained to be within the values in the block.
BlockEnums.numblocks
— Functionnumblocks(t::Type{<:BlockEnum{T}}) where T <: Integer
Return the number of blocks for which bookkeeping has been set up. The set of values of t
is the nonzero values of T
, which is typically very large. Bookkeeping of blocks requires storage. So you can only set up some of the blocks for use.
BlockEnums.blocklength
— Functionblocklength(t::Type{<:BlockEnum})
Get the length of blocks that the range of values of t
is partitioned into.
BlockEnums.blockindex
— Functionblockindex(v::BlockEnum)
Get the index of the block of values v
belongs to.
BlockEnums.blockrange
— Functionblockrange(t::Type{<:BlockEnum}, blockind)
Return the range of values of t
in block number blockind
.
BlockEnums.add!
— Functionadd!(enumname, syms...)
Add symbols syms
to BlockEnum
enumname
. This function is called by the macro @add
.
BlockEnums.@add
— Macro@add enunmame syms...
Add symbols syms
to BlockEnum
named enumname
.
Examples
@blockenum MyEnum
@add MyEnum a b
julia> a
a::MyEnum = 0
julia> b
b::MyEnum = 1
BlockEnums.add_in_block!
— Functionadd_in_block!(a, _block::Union{Integer, BlockEnum}, syms...)
This is the function called by @addinblock
.
BlockEnums.@addinblock
— Macro@addinblock EnumName blocknum sym1 [sym2,..]
Add symbols sym1
, sym2
, etc. to block number blocknum
of BlockEnum
named EnunName
.
BlockEnums.inblock
— Functioninblock(benum::BlockEnum, blockind)
Return true
if benum
is in block number blockind
of the type of benum
.
BlockEnums.gtblock
— Functiongtblock(benum::BlockEnum, blockind)
Return true
if benum
is in a block number of the type of benum
larger than blockind
.
BlockEnums.ltblock
— Functionltblock(benum::BlockEnum, blockind)
Return true
if benum
is in a block number of the type of benum
smaller than blockind
.
Index
BlockEnums
BlockEnums.BlockEnum
Base.instances
Base.length
BlockEnums.add!
BlockEnums.add_in_block!
BlockEnums.addblocks!
BlockEnums.basetype
BlockEnums.blockindex
BlockEnums.blocklength
BlockEnums.blockrange
BlockEnums.compact_show
BlockEnums.getmodule
BlockEnums.gtblock
BlockEnums.inblock
BlockEnums.ltblock
BlockEnums.maxvalind
BlockEnums.namemap
BlockEnums.numblocks
BlockEnums.val
BlockEnums.@add
BlockEnums.@addinblock
BlockEnums.@blockenum