Sequence
pthreads $ ConcurrentSequence :: SELF
Type of this instance, automatically specialized in every classpthreads $ ConcurrentSequence :: append
Add each item ofcoll
after the last.
pthreads $ ConcurrentSequence :: insert_all
Insert all elements at a given position, following elements are shifted.pthreads $ ConcurrentSequence :: prepend
Add all items ofcoll
before the first one.
pthreads $ ConcurrentSequence :: remove_at
Remove the item atindex
and shift all following elements
core :: Collection :: CONCURRENT
Type of the concurrent variant of this collectionpthreads :: ConcurrentCollection :: REAL
Type of the equivalent non thread-safe collectionserialization :: Serializable :: accept_json_serializer
Refinable service to customize the serialization of this class to JSONserialization :: Serializable :: accept_msgpack_attribute_counter
Hook to customize the behavior of theAttributeCounter
serialization :: Serializable :: accept_msgpack_serializer
Hook to customize the serialization of this class to MessagePackserialization :: Serializable :: add_to_bundle
Called by[]=
to dynamically choose the appropriate method according
core :: Object :: class_factory
Implementation used byget_class
to create the specific class.
core :: Collection :: combinations
Allr
-length combinations on self (in same order) without repeated elements.
core :: Collection :: combinations_with_replacement
Allr
-length combination on self (in same order) with repeated elements.
serialization :: Serializable :: core_serialize_to
Actual serialization ofself
to serializer
core :: Object :: defaultinit
core :: SequenceRead :: defaultinit
core :: Sequence :: defaultinit
core :: SimpleCollection :: defaultinit
core :: Collection :: defaultinit
serialization :: Serializable :: from_deserializer
Create an instance of this class from thedeserializer
core :: SequenceRead :: get_or_default
Try to get an element, returndefault
if the index
is invalid.
core :: SequenceRead :: get_or_null
Try to get an element, returnnull
if the index
is invalid.
core :: Collection :: has_all
Does the collection contain at least each element ofother
?
core :: Collection :: has_any
Does the collection contain at least one element ofother
?
core :: Collection :: has_exactly
Does the collection contain exactly all the elements ofother
?
core :: SequenceRead :: index_of_from
The index of the first occurrence ofitem
, starting from pos.
core :: Sequence :: insert_all
Insert all elements at a given position, following elements are shifted.core :: Object :: is_same_instance
Return true ifself
and other
are the same instance (i.e. same identity).
core :: Object :: is_same_serialized
Isself
the same as other
in a serialization context?
core :: Object :: is_same_type
Return true ifself
and other
have the same dynamic type.
core :: SequenceRead :: iterator_from
Gets a new Iterator starting at positionpos
core :: SequenceRead :: last_index_of
The index of the last occurrence ofitem
.
core :: SequenceRead :: last_index_of_from
The index of the last occurrence ofitem
starting from pos
and decrementing.
core :: SequenceRead :: modulo_index
Returns the real index for a modulo index.serialization :: Serializable :: msgpack_extra_array_items
Hook to request a larger than usual metadata arraypthreads :: ConcurrentCollection :: mutex=
Mutex
used to synchronize access to self
core :: Object :: output_class_name
Display class name on stdout (debug only).core :: Collection :: permutations
Allr
-length permutations on self (all possible ordering) without repeated elements.
core :: Collection :: product
Cartesian product, overr
times self
.
pthreads :: ConcurrentCollection :: real_collection
Collection wrapped byself
pthreads :: ConcurrentCollection :: real_collection=
Collection wrapped byself
core :: RemovableCollection :: remove
Remove an occurrence ofitem
core :: RemovableCollection :: remove_all
Remove all occurrences ofitem
core :: SequenceRead :: reverse_iterator
Gets an iterator starting at the end and going backwardscore :: SequenceRead :: reverse_iterator_from
Gets an iterator on the chars of self starting frompos
serialization :: Serializable :: serialize_msgpack
Serializeself
to MessagePack bytes
serialization :: Serializable :: serialize_to
Serializeself
to serializer
serialization :: Serializable :: serialize_to_json
Serializeself
to JSON
core :: Collection :: to_concurrent
Wrapsself
in a thread-safe collection
core :: Collection :: to_counter
Create and fill up a counter with the elements of `self.core :: Collection :: to_curlslist
Convert Collection[String] to CURLSListserialization :: Serializable :: to_pretty_json
Serializeself
to plain pretty JSON
core :: Collection :: to_shuffle
Return a new array made of elements in a random order.pthreads :: ConcurrentCollection
A concurrent variant to the standardCollection
Serializer::serialize
pthreads :: ConcurrentSequenceRead
A concurrent variant to the standardSequenceRead
Array
List
ConcurrentList
pthreads :: ReverseBlockingQueue
A collection whichis_empty
method blocks until it's empty
# A concurrent variant to the standard `Sequence`
abstract class ConcurrentSequence[E]
super ConcurrentSequenceRead[E]
super Sequence[E]
redef type REAL: Sequence[E]
redef fun []=(index, e)
do
mutex.lock
real_collection[index] = e
mutex.unlock
end
redef fun add(e)
do
mutex.lock
real_collection.add e
mutex.unlock
end
redef fun append(e)
do
mutex.lock
real_collection.append e
mutex.unlock
end
redef fun first=(e)
do
mutex.lock
real_collection.first = e
mutex.unlock
end
redef fun insert(e, i)
do
mutex.lock
real_collection.insert(e, i)
mutex.unlock
end
redef fun insert_all(from, pos)
do
mutex.lock
real_collection
mutex.unlock
end
redef fun last=(e)
do
mutex.lock
real_collection.last = e
mutex.unlock
end
redef fun pop
do
mutex.lock
var r = real_collection.pop
mutex.unlock
return r
end
redef fun prepend(e)
do
mutex.lock
real_collection.prepend e
mutex.unlock
end
redef fun push(e)
do
mutex.lock
real_collection.push e
mutex.unlock
end
redef fun remove_at(index)
do
mutex.lock
real_collection.remove_at(index)
mutex.unlock
end
redef fun shift
do
mutex.lock
var r = real_collection.shift
mutex.unlock
return r
end
redef fun unshift(e)
do
mutex.lock
real_collection.unshift(e)
mutex.unlock
end
redef fun subarray(start, len)
do
mutex.lock
var r = real_collection.subarray(start, len)
mutex.unlock
return r
end
end
lib/pthreads/concurrent_collections.nit:277,1--384,3