|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectorg.codehaus.groovy.runtime.DefaultGroovyMethodsSupport
org.codehaus.groovy.runtime.DefaultGroovyMethods
public class DefaultGroovyMethods
This class defines new groovy methods which appear on normal JDK
classes inside the Groovy environment. Static methods are used with the
first parameter being the destination class,
i.e. public static String reverse(String self)
provides a reverse()
method for String
.
NOTE: While this class contains many 'public' static methods, it is primarily regarded as an internal class (its internal package name suggests this also). We value backwards compatibility of these methods when used within Groovy but value less backwards compatibility at the Java method call level. I.e. future versions of Groovy may remove or move a method call in this file but would normally aim to keep the method available from within Groovy.
Nested Class Summary |
---|
Nested classes/interfaces inherited from class org.codehaus.groovy.runtime.DefaultGroovyMethodsSupport |
---|
DefaultGroovyMethodsSupport.RangeInfo |
Field Summary | |
---|---|
static Class[] |
additionals
|
Constructor Summary | |
---|---|
DefaultGroovyMethods()
|
Method Summary | ||
---|---|---|
static double |
abs(Double number)
Get the absolute value |
|
static float |
abs(Float number)
Get the absolute value |
|
static long |
abs(Long number)
Get the absolute value |
|
static int |
abs(Number number)
Get the absolute value |
|
static Socket |
accept(ServerSocket serverSocket,
boolean runInANewThread,
Closure closure)
Accepts a connection and passes the resulting Socket to the closure which runs in a new Thread or the calling thread, as needed. |
|
static Socket |
accept(ServerSocket serverSocket,
Closure closure)
Accepts a connection and passes the resulting Socket to the closure which runs in a new Thread. |
|
static
|
addAll(Collection<T> self,
T[] items)
Modifies the collection by adding all of the elements in the specified array to the collection. |
|
static
|
addAll(List<T> self,
int index,
T[] items)
Modifies this list by inserting all of the elements in the specified array into the list at the specified position. |
|
static void |
addShutdownHook(Object self,
Closure closure)
Allows the usage of addShutdownHook without getting the runtime first. |
|
static BitSet |
and(BitSet left,
BitSet right)
Bitwise AND together two BitSets. |
|
static Boolean |
and(Boolean left,
Boolean right)
Logical conjunction of two boolean operators. |
|
static Number |
and(Number left,
Number right)
Bitwise AND together two Numbers. |
|
static
|
any(Map<K,V> self,
Closure<?> closure)
Iterates over the entries of a map, and checks whether a predicate is valid for at least one entry. |
|
static boolean |
any(Object self)
Iterates over the elements of a collection, and checks whether at least one element is true according to the Groovy Truth. |
|
static boolean |
any(Object self,
Closure closure)
Iterates over the contents of an object or collection, and checks whether a predicate is valid for at least one element. |
|
static void |
append(File file,
byte[] bytes)
Append bytes to the end of a File. |
|
static void |
append(File self,
InputStream stream)
Append binary data to the file. |
|
static void |
append(File file,
Object text)
Append the text at the end of the File. |
|
static void |
append(File file,
Object text,
String charset)
Append the text at the end of the File, using a specified encoding. |
|
static boolean |
asBoolean(Boolean bool)
Coerce an Boolean instance to a boolean value. |
|
static boolean |
asBoolean(boolean[] array)
Coerces a boolean array to a boolean value. |
|
static boolean |
asBoolean(byte[] array)
Coerces a byte array to a boolean value. |
|
static boolean |
asBoolean(char[] array)
Coerces a char array to a boolean value. |
|
static boolean |
asBoolean(Character character)
Coerce a character to a boolean value. |
|
static boolean |
asBoolean(CharSequence string)
Coerce a string (an instance of CharSequence) to a boolean value. |
|
static boolean |
asBoolean(Collection collection)
Coerce a collection instance to a boolean value. |
|
static boolean |
asBoolean(double[] array)
Coerces a double array to a boolean value. |
|
static boolean |
asBoolean(Enumeration enumeration)
Coerce an enumeration instance to a boolean value. |
|
static boolean |
asBoolean(float[] array)
Coerces a float array to a boolean value. |
|
static boolean |
asBoolean(int[] array)
Coerces an int array to a boolean value. |
|
static boolean |
asBoolean(Iterator iterator)
Coerce an iterator instance to a boolean value. |
|
static boolean |
asBoolean(long[] array)
Coerces a long array to a boolean value. |
|
static boolean |
asBoolean(Map map)
Coerce a map instance to a boolean value. |
|
static boolean |
asBoolean(Matcher matcher)
Coerce a Matcher instance to a boolean value. |
|
static boolean |
asBoolean(Number number)
Coerce a number to a boolean value. |
|
static boolean |
asBoolean(Object object)
Coerce an object instance to a boolean value. |
|
static boolean |
asBoolean(Object[] array)
Coerce an Object array to a boolean value. |
|
static boolean |
asBoolean(short[] array)
Coerces a short array to a boolean value. |
|
static
|
asImmutable(Collection<? extends T> self)
A convenience method for creating an immutable Collection. |
|
static
|
asImmutable(List<? extends T> self)
A convenience method for creating an immutable list |
|
static
|
asImmutable(Map<? extends K,? extends V> self)
A convenience method for creating an immutable map. |
|
static
|
asImmutable(Set<? extends T> self)
A convenience method for creating an immutable list. |
|
static
|
asImmutable(SortedMap<K,? extends V> self)
A convenience method for creating an immutable sorted map. |
|
static
|
asImmutable(SortedSet<T> self)
A convenience method for creating an immutable sorted set. |
|
static
|
asList(Collection<T> self)
Converts this Collection to a List. |
|
static
|
asSynchronized(Collection<T> self)
A convenience method for creating a synchronized Collection. |
|
static
|
asSynchronized(List<T> self)
A convenience method for creating a synchronized List. |
|
static
|
asSynchronized(Map<K,V> self)
A convenience method for creating a synchronized Map. |
|
static
|
asSynchronized(Set<T> self)
A convenience method for creating a synchronized Set. |
|
static
|
asSynchronized(SortedMap<K,V> self)
A convenience method for creating a synchronized SortedMap. |
|
static
|
asSynchronized(SortedSet<T> self)
A convenience method for creating a synchronized SortedSet. |
|
static
|
asType(CharSequence self,
Class<T> c)
Provides a method to perform custom 'dynamic' type conversion to the given class using the as operator. |
|
static
|
asType(Closure cl,
Class<T> clazz)
Coerces the closure to an implementation of the given class. |
|
static
|
asType(Collection col,
Class<T> clazz)
Converts the given collection to another type. |
|
static
|
asType(File f,
Class<T> c)
Converts this File to a Writable or delegates to default
asType(java.lang.Object, java.lang.Class) . |
|
static
|
asType(GString self,
Class<T> c)
Converts the GString to a File, or delegates to the default asType(java.lang.Object, java.lang.Class) |
|
static
|
asType(Map map,
Class<T> clazz)
Coerces this map to the given type, using the map's keys as the public method names, and values as the implementation. |
|
static
|
asType(Number self,
Class<T> c)
Transform this number to a the given type, using the 'as' operator. |
|
static
|
asType(Object[] ary,
Class<T> clazz)
Converts the given array to either a List, Set, or SortedSet. |
|
static
|
asType(Object obj,
Class<T> type)
Converts a given object to a type. |
|
static
|
asType(String self,
Class<T> c)
Provides a method to perform custom 'dynamic' type conversion to the given class using the as operator. |
|
static File |
asWritable(File file)
Converts this File to a Writable . |
|
static File |
asWritable(File file,
String encoding)
Allows a file to return a Writable implementation that can output itself to a Writer stream. |
|
static BitSet |
bitwiseNegate(BitSet self)
Bitwise NEGATE a BitSet. |
|
static Pattern |
bitwiseNegate(CharSequence self)
Turns a CharSequence into a regular expression Pattern |
|
static Pattern |
bitwiseNegate(String self)
Turns a String into a regular expression Pattern |
|
protected static
|
callClosureForLine(Closure<T> closure,
String line,
int counter)
|
|
protected static
|
callClosureForMapEntry(Closure<T> closure,
Map.Entry entry)
|
|
protected static
|
callClosureForMapEntryAndCounter(Closure<T> closure,
Map.Entry entry,
int counter)
|
|
static CharSequence |
capitalize(CharSequence self)
Convenience method to capitalize the first letter of a CharSequence. |
|
static String |
capitalize(String self)
Convenience method to capitalize the first letter of a string (typically the first letter of a word). |
|
static CharSequence |
center(CharSequence self,
Number numberOfChars)
Pad a CharSequence to a minimum length specified by numberOfChars by adding the space character around it as many times as needed so that it remains centered. |
|
static CharSequence |
center(CharSequence self,
Number numberOfChars,
CharSequence padding)
Pad a CharSequence to a minimum length specified by numberOfChars, appending the supplied padding CharSequence around the original as many times as needed keeping it centered. |
|
static String |
center(String self,
Number numberOfChars)
Pad a String to a minimum length specified by numberOfChars by adding the space character around it as many times as needed so that it remains centered. |
|
static String |
center(String self,
Number numberOfChars,
String padding)
Pad a String to a minimum length specified by numberOfChars, appending the supplied padding String around the original as many times as needed keeping it centered. |
|
static
|
collate(List<T> self,
int size)
Collates this list into sub-lists of length size . |
|
static
|
collate(List<T> self,
int size,
boolean keepRemainder)
Collates this list into sub-lists of length size . |
|
static
|
collate(List<T> self,
int size,
int step)
Collates this list into sub-lists of length size stepping through the code step
elements for each subList. |
|
static
|
collate(List<T> self,
int size,
int step,
boolean keepRemainder)
Collates this list into sub-lists of length size stepping through the code step
elements for each sub-list. |
|
static
|
collect(Collection<?> self,
Closure<T> transform)
Iterates through this collection transforming each entry into a new value using the transform closure
returning a list of transformed values. |
|
static
|
collect(Collection<?> self,
Collection<T> collector,
Closure<? extends T> transform)
Iterates through this collection transforming each value into a new value using the transform closure
and adding it to the supplied collector . |
|
static
|
collect(Collection<T> self)
Iterates through this collection transforming each entry into a new value using Closure.IDENTITY as a transformer, basically returning a list of items copied from the original collection. |
|
static
|
collect(Map<?,?> self,
Collection<T> collector,
Closure<? extends T> transform)
Iterates through this Map transforming each map entry into a new value using the transform closure
returning the collector with all transformed vakues added to it. |
|
static
|
collect(Map self,
Closure<T> transform)
Iterates through this Map transforming each map entry into a new value using the transform closure
returning a list of transformed values. |
|
static Collection |
collect(Object self)
Iterates through this aggregate Object transforming each item into a new value using Closure.IDENTITY as a transformer, basically returning a list of items copied from the original object. |
|
static
|
collect(Object self,
Closure<T> transform)
Iterates through this aggregate Object transforming each item into a new value using the transform closure, returning a list of transformed values. |
|
static
|
collect(Object self,
Collection<T> collector,
Closure<? extends T> transform)
Iterates through this aggregate Object transforming each item into a new value using the transform closure
and adding it to the supplied collector . |
|
static List |
collectAll(Collection self,
Closure transform)
Deprecated. Use collectNested instead |
|
static Collection |
collectAll(Collection self,
Collection collector,
Closure transform)
Deprecated. Use collectNested instead |
|
static
|
collectEntries(Collection<?> self)
A variant of collectEntries using the identity closure as the transform. |
|
static
|
collectEntries(Collection<?> self,
Closure<?> transform)
Iterates through this Collection transforming each item using the transform closure
and returning a map of the resulting transformed entries. |
|
static
|
collectEntries(Collection<?> self,
Map<K,V> collector)
A variant of collectEntries using the identity closure as the transform. |
|
static
|
collectEntries(Collection<?> self,
Map<K,V> collector,
Closure<?> transform)
Iterates through this Collection transforming each item using the closure as a transformer into a map entry, returning a map of the transformed entries. |
|
static Map<?,?> |
collectEntries(Map<?,?> self,
Closure<?> transform)
Iterates through this Map transforming each entry using the transform closure
and returning a map of the transformed entries. |
|
static
|
collectEntries(Map<?,?> self,
Map<K,V> collector,
Closure<?> transform)
Iterates through this Map transforming each map entry using the transform closure
returning a map of the transformed entries. |
|
static
|
collectEntries(Object[] self)
A variant of collectEntries using the identity closure as the transform. |
|
static
|
collectEntries(Object[] self,
Closure<?> transform)
Iterates through this array transforming each item using the transform closure
and returning a map of the resulting transformed entries. |
|
static
|
collectEntries(Object[] self,
Map<K,V> collector)
A variant of collectEntries using the identity closure as the transform. |
|
static
|
collectEntries(Object[] self,
Map<K,V> collector,
Closure<?> transform)
Iterates through this array transforming each item using the transform closure
and returning a map of the resulting transformed entries. |
|
static
|
collectMany(Collection self,
Closure<Collection<? extends T>> projection)
Projects each item from a source collection to a collection and concatenates (flattens) the resulting collections into a single list. |
|
static
|
collectMany(Collection self,
Collection<T> collector,
Closure<Collection<? extends T>> projection)
Projects each item from a source collection to a result collection and concatenates (flattens) the resulting collections adding them into the collector . |
|
static
|
collectMany(Iterator<Object> self,
Closure<Collection<? extends T>> projection)
Projects each item from a source iterator to a collection and concatenates (flattens) the resulting collections into a single list. |
|
static
|
collectMany(Map<?,?> self,
Closure<Collection<? extends T>> projection)
Projects each item from a source map to a result collection and concatenates (flattens) the resulting collections adding them into a collection. |
|
static
|
collectMany(Map<?,?> self,
Collection<T> collector,
Closure<Collection<? extends T>> projection)
Projects each item from a source map to a result collection and concatenates (flattens) the resulting collections adding them into the collector . |
|
static
|
collectMany(Object[] self,
Closure<Collection<? extends T>> projection)
Projects each item from a source array to a collection and concatenates (flattens) the resulting collections into a single list. |
|
static List |
collectNested(Collection self,
Closure transform)
Recursively iterates through this collection transforming each non-Collection value into a new value using the closure as a transformer. |
|
static Collection |
collectNested(Collection self,
Collection collector,
Closure transform)
Recursively iterates through this collection transforming each non-Collection value into a new value using the transform closure. |
|
static List |
combinations(Collection self)
Adds GroovyCollections#combinations(Collection) as a method on collections. |
|
static int |
compareTo(Character left,
Character right)
Compare two Characters. |
|
static int |
compareTo(Character left,
Number right)
Compare a Character and a Number. |
|
static int |
compareTo(Number left,
Character right)
Compare a Number and a Character. |
|
static int |
compareTo(Number left,
Number right)
Compare two Numbers. |
|
static boolean |
contains(boolean[] self,
Object value)
Checks whether the array contains the given value. |
|
static boolean |
contains(byte[] self,
Object value)
Checks whether the array contains the given value. |
|
static boolean |
contains(char[] self,
Object value)
Checks whether the array contains the given value. |
|
static boolean |
contains(CharSequence self,
CharSequence text)
Provide an implementation of contains() like Collection.contains(java.lang.Object) to make CharSequences more polymorphic. |
|
static boolean |
contains(double[] self,
Object value)
Checks whether the array contains the given value. |
|
static boolean |
contains(float[] self,
Object value)
Checks whether the array contains the given value. |
|
static boolean |
contains(int[] self,
Object value)
Checks whether the array contains the given value. |
|
static boolean |
contains(long[] self,
Object value)
Checks whether the array contains the given value. |
|
static boolean |
contains(Object[] self,
Object value)
Checks whether the array contains the given value. |
|
static boolean |
contains(short[] self,
Object value)
Checks whether the array contains the given value. |
|
static boolean |
contains(String self,
String text)
Provide an implementation of contains() like Collection.contains(java.lang.Object) to make Strings more polymorphic. |
|
static boolean |
containsAll(Collection self,
Object[] items)
Returns true if this collection contains all of the elements in the specified array. |
|
static Number |
count(boolean[] self,
Object value)
Counts the number of occurrences of the given value inside this array. |
|
static Number |
count(byte[] self,
Object value)
Counts the number of occurrences of the given value inside this array. |
|
static Number |
count(char[] self,
Object value)
Counts the number of occurrences of the given value inside this array. |
|
static int |
count(CharSequence self,
CharSequence text)
Count the number of occurrences of a sub CharSequence. |
|
static Number |
count(Collection self,
Closure closure)
Counts the number of occurrences which satisfy the given closure from inside this collection. |
|
static Number |
count(Collection self,
Object value)
Counts the number of occurrences of the given value inside this collection. |
|
static Number |
count(double[] self,
Object value)
Counts the number of occurrences of the given value inside this array. |
|
static Number |
count(float[] self,
Object value)
Counts the number of occurrences of the given value inside this array. |
|
static Number |
count(int[] self,
Object value)
Counts the number of occurrences of the given value inside this array. |
|
static Number |
count(Iterator self,
Closure closure)
Counts the number of occurrences which satisfy the given closure from the items within this Iterator. |
|
static Number |
count(Iterator self,
Object value)
Counts the number of occurrences of the given value from the items within this Iterator. |
|
static Number |
count(long[] self,
Object value)
Counts the number of occurrences of the given value inside this array. |
|
static Number |
count(Map self,
Closure<?> closure)
Counts the number of occurrences which satisfy the given closure from inside this map. |
|
static Number |
count(Object[] self,
Closure closure)
Counts the number of occurrences which satisfy the given closure from inside this array. |
|
static Number |
count(Object[] self,
Object value)
Counts the number of occurrences of the given value inside this array. |
|
static Number |
count(short[] self,
Object value)
Counts the number of occurrences of the given value inside this array. |
|
static int |
count(String self,
String text)
Count the number of occurrences of a substring. |
|
static
|
countBy(Collection self,
Closure<K> closure)
Sorts all collection members into groups determined by the supplied mapping closure and counts the group size. |
|
static
|
countBy(Iterator self,
Closure<K> closure)
Sorts all iterator items into groups determined by the supplied mapping closure and counts the group size. |
|
static
|
countBy(Map self,
Closure<K> closure)
Groups the members of a map into groups determined by the supplied mapping closure and counts the frequency of the created groups. |
|
static
|
countBy(Object[] self,
Closure<K> closure)
Sorts all array members into groups determined by the supplied mapping closure and counts the group size. |
|
protected static StringBufferWriter |
createStringBufferWriter(StringBuffer self)
|
|
protected static StringWriter |
createStringWriter(String self)
|
|
static boolean |
deleteDir(File self)
Deletes a directory with all contained files and subdirectories. |
|
static CharSequence |
denormalize(CharSequence self)
Return a CharSequence with lines (separated by LF, CR/LF, or CR) terminated by the platform specific line separator. |
|
static String |
denormalize(String self)
Return a String with lines (separated by LF, CR/LF, or CR) terminated by the platform specific line separator. |
|
static boolean |
disjoint(Collection left,
Collection right)
Returns true if the intersection of two collections is empty. |
|
static Number |
div(Character left,
Character right)
Divide one Character by another. |
|
static Number |
div(Character left,
Number right)
Divide a Character by a Number. |
|
static Number |
div(Number left,
Character right)
Divide a Number by a Character. |
|
static void |
downto(BigDecimal self,
Number to,
Closure closure)
Iterates from this number down to the given number, inclusive, decrementing by one each time. |
|
static void |
downto(BigInteger self,
Number to,
Closure closure)
Iterates from this number down to the given number, inclusive, decrementing by one each time. |
|
static void |
downto(double self,
Number to,
Closure closure)
Iterates from this number down to the given number, inclusive, decrementing by one each time. |
|
static void |
downto(Double self,
Number to,
Closure closure)
Iterates from this number down to the given number, inclusive, decrementing by one each time. |
|
static void |
downto(float self,
Number to,
Closure closure)
Iterates from this number down to the given number, inclusive, decrementing by one each time. |
|
static void |
downto(Float self,
Number to,
Closure closure)
Iterates from this number down to the given number, inclusive, decrementing by one each time. |
|
static void |
downto(long self,
Number to,
Closure closure)
Iterates from this number down to the given number, inclusive, decrementing by one each time. |
|
static void |
downto(Long self,
Number to,
Closure closure)
Iterates from this number down to the given number, inclusive, decrementing by one each time. |
|
static void |
downto(Number self,
Number to,
Closure closure)
Iterates from this number down to the given number, inclusive, decrementing by one each time. |
|
static CharSequence |
drop(CharSequence self,
int num)
Drops the given number of chars from the head of this CharSequence if they are available. |
|
static
|
drop(Iterable<T> self,
int num)
Drops the given number of elements from the head of this Iterable. |
|
static
|
drop(Iterator<T> self,
int num)
Drops the given number of elements from the head of this iterator if they are available. |
|
static
|
drop(List<T> self,
int num)
Drops the given number of elements from the head of this list if they are available. |
|
static
|
drop(Map<K,V> self,
int num)
Drops the given number of key/value pairs from the head of this map if they are available. |
|
static
|
drop(T[] self,
int num)
Drops the given number of elements from the head of this array if they are available. |
|
static
|
dropWhile(Iterable<T> self,
Closure<?> condition)
Returns a suffix of this Iterable where elements are dropped from the front while the given closure evaluates to true. |
|
static
|
dropWhile(Iterator<T> self,
Closure<?> condition)
Creates an Iterator that returns a suffix of the elements from an original Iterator. |
|
static
|
dropWhile(List<T> self,
Closure<?> condition)
Returns a suffix of this List where elements are dropped from the front while the given Closure evaluates to true. |
|
static
|
dropWhile(Map<K,V> self,
Closure<?> condition)
Create a suffix of the given Map by dropping as many entries as possible from the front of the original Map such that calling the given closure condition evaluates to true when passed each of the dropped entries (or key/value pairs). |
|
static
|
dropWhile(T[] self,
Closure<?> condition)
Create a suffix of the given array by dropping as many elements as possible from the front of the original array such that calling the given closure condition evaluates to true when passed each of the dropped elements. |
|
static String |
dump(Object self)
Generates a detailed dump string of an object showing its class, hashCode and fields. |
|
static
|
each(Map<K,V> self,
Closure closure)
Allows a Map to be iterated through using a closure. |
|
static
|
each(T self,
Closure closure)
Iterates through an aggregate type or data structure, passing each item to the given closure. |
|
static void |
eachByte(byte[] self,
Closure closure)
Traverse through each byte of this byte array. |
|
static void |
eachByte(Byte[] self,
Closure closure)
Traverse through each byte of this Byte array. |
|
static void |
eachByte(File self,
Closure closure)
Traverse through each byte of this File |
|
static void |
eachByte(File self,
int bufferLen,
Closure closure)
Traverse through the bytes of this File, bufferLen bytes at a time. |
|
static void |
eachByte(InputStream is,
Closure closure)
Traverse through each byte of the specified stream. |
|
static void |
eachByte(InputStream is,
int bufferLen,
Closure closure)
Traverse through each the specified stream reading bytes into a buffer and calling the 2 parameter closure with this buffer and the number of bytes. |
|
static void |
eachByte(URL url,
Closure closure)
Reads the InputStream from this URL, passing each byte to the given closure. |
|
static void |
eachByte(URL url,
int bufferLen,
Closure closure)
Reads the InputStream from this URL, passing a byte[] and a number of bytes to the given closure. |
|
static void |
eachDir(File self,
Closure closure)
Invokes the closure for each subdirectory in this directory, ignoring regular files. |
|
static void |
eachDirMatch(File self,
Object nameFilter,
Closure closure)
Invokes the closure for each subdirectory whose name (dir.name) matches the given nameFilter in the given directory - calling the isCase(java.lang.Object, java.lang.Object) method to determine if a match occurs. |
|
static void |
eachDirRecurse(File self,
Closure closure)
Invokes the closure for each descendant directory of this directory. |
|
static void |
eachFile(File self,
Closure closure)
Invokes the closure for each 'child' file in this 'parent' folder/directory. |
|
static void |
eachFile(File self,
FileType fileType,
Closure closure)
Invokes the closure for each 'child' file in this 'parent' folder/directory. |
|
static void |
eachFileMatch(File self,
FileType fileType,
Object nameFilter,
Closure closure)
Invokes the closure for each file whose name (file.name) matches the given nameFilter in the given directory - calling the isCase(java.lang.Object, java.lang.Object) method to determine if a match occurs. |
|
static void |
eachFileMatch(File self,
Object nameFilter,
Closure closure)
Invokes the closure for each file whose name (file.name) matches the given nameFilter in the given directory - calling the isCase(java.lang.Object, java.lang.Object) method to determine if a match occurs. |
|
static void |
eachFileRecurse(File self,
Closure closure)
Invokes the closure for each descendant file in this directory. |
|
static void |
eachFileRecurse(File self,
FileType fileType,
Closure closure)
Invokes the closure for each descendant file in this directory. |
|
static
|
eachLine(CharSequence self,
Closure<T> closure)
Iterates through this CharSequence line by line. |
|
static
|
eachLine(CharSequence self,
int firstLine,
Closure<T> closure)
Iterates through this CharSequence line by line. |
|
static
|
eachLine(File self,
Closure<T> closure)
Iterates through this file line by line. |
|
static
|
eachLine(File self,
int firstLine,
Closure<T> closure)
Iterates through this file line by line. |
|
static
|
eachLine(File self,
String charset,
Closure<T> closure)
Iterates through this file line by line. |
|
static
|
eachLine(File self,
String charset,
int firstLine,
Closure<T> closure)
Iterates through this file line by line. |
|
static
|
eachLine(InputStream stream,
Closure<T> closure)
Iterates through this stream, passing each line to the given 1 or 2 arg closure. |
|
static
|
eachLine(InputStream stream,
int firstLine,
Closure<T> closure)
Iterates through this stream, passing each line to the given 1 or 2 arg closure. |
|
static
|
eachLine(InputStream stream,
String charset,
Closure<T> closure)
Iterates through this stream reading with the provided charset, passing each line to the given 1 or 2 arg closure. |
|
static
|
eachLine(InputStream stream,
String charset,
int firstLine,
Closure<T> closure)
Iterates through this stream reading with the provided charset, passing each line to the given 1 or 2 arg closure. |
|
static
|
eachLine(Reader self,
Closure<T> closure)
Iterates through the given reader line by line. |
|
static
|
eachLine(Reader self,
int firstLine,
Closure<T> closure)
Iterates through the given reader line by line. |
|
static
|
eachLine(String self,
Closure<T> closure)
Iterates through this String line by line. |
|
static
|
eachLine(String self,
int firstLine,
Closure<T> closure)
Iterates through this String line by line. |
|
static
|
eachLine(URL url,
Closure<T> closure)
Iterates through the lines read from the URL's associated input stream passing each line to the given 1 or 2 arg closure. |
|
static
|
eachLine(URL url,
int firstLine,
Closure<T> closure)
Iterates through the lines read from the URL's associated input stream passing each line to the given 1 or 2 arg closure. |
|
static
|
eachLine(URL url,
String charset,
Closure<T> closure)
Iterates through the lines read from the URL's associated input stream passing each line to the given 1 or 2 arg closure. |
|
static
|
eachLine(URL url,
String charset,
int firstLine,
Closure<T> closure)
Iterates through the lines read from the URL's associated input stream passing each line to the given 1 or 2 arg closure. |
|
static String |
eachMatch(CharSequence self,
CharSequence regex,
Closure closure)
Process each regex group matched substring of the given CharSequence. |
|
static String |
eachMatch(CharSequence self,
Pattern pattern,
Closure closure)
Process each regex group matched substring of the given pattern. |
|
static String |
eachMatch(String self,
Pattern pattern,
Closure closure)
Process each regex group matched substring of the given pattern. |
|
static String |
eachMatch(String self,
String regex,
Closure closure)
Process each regex group matched substring of the given string. |
|
static void |
eachObject(File self,
Closure closure)
Iterates through the given file object by object. |
|
static void |
eachObject(ObjectInputStream ois,
Closure closure)
Iterates through the given object stream object by object. |
|
static
|
eachPermutation(Collection<T> self,
Closure closure)
Iterates over all permutations of a collection, running a closure for each iteration. |
|
static
|
eachWithIndex(Map<K,V> self,
Closure closure)
Allows a Map to be iterated through using a closure. |
|
static
|
eachWithIndex(T self,
Closure closure)
Iterates through an aggregate type or data structure, passing each item and the item's index (a counter starting at zero) to the given closure. |
|
static boolean |
equals(int[] left,
int[] right)
Compare the contents of this array to the contents of the given array. |
|
static boolean |
equals(List left,
List right)
Compare the contents of two Lists. |
|
static boolean |
equals(List left,
Object[] right)
Determines if the contents of this list are equal to the contents of the given array in the same order. |
|
static boolean |
equals(Map self,
Map other)
Compares two Maps treating coerced numerical values as identical. |
|
static boolean |
equals(Object[] left,
List right)
Determines if the contents of this array are equal to the contents of the given list, in the same order. |
|
static
|
equals(Set<T> self,
Set<T> other)
Compare the contents of two Sets for equality using Groovy's coercion rules. |
|
static
|
every(Map<K,V> self,
Closure closure)
Iterates over the entries of a map, and checks whether a predicate is valid for all entries. |
|
static boolean |
every(Object self)
Iterates over every element of a collection, and checks whether all elements are true according to the Groovy Truth. |
|
static boolean |
every(Object self,
Closure closure)
Used to determine if the given predicate closure is valid (i.e. |
|
static Process |
execute(List commands)
Executes the command specified by the given list. |
|
static Process |
execute(List commands,
List envp,
File dir)
Executes the command specified by the given list, with the environment defined by envp and under the working directory dir . |
|
static Process |
execute(List commands,
String[] envp,
File dir)
Executes the command specified by the given list, with the environment defined by envp and under the working directory dir . |
|
static Process |
execute(String self)
Executes the command specified by self as a command-line process. |
|
static Process |
execute(String[] commandArray)
Executes the command specified by the given String array. |
|
static Process |
execute(String[] commandArray,
List envp,
File dir)
Executes the command specified by the String array given in the first parameter,
with the environment defined by envp and under the working directory dir . |
|
static Process |
execute(String[] commandArray,
String[] envp,
File dir)
Executes the command specified by the String array given in the first parameter,
with the environment defined by envp and under the working directory dir . |
|
static Process |
execute(String self,
List envp,
File dir)
Executes the command specified by self with environment defined
by envp and under the working directory dir . |
|
static Process |
execute(String self,
String[] envp,
File dir)
Executes the command specified by self with environment defined by envp
and under the working directory dir . |
|
static CharSequence |
expand(CharSequence self)
Expands all tabs into spaces with tabStops of size 8. |
|
static CharSequence |
expand(CharSequence self,
int tabStop)
Expands all tabs into spaces. |
|
static String |
expand(String self)
Expands all tabs into spaces with tabStops of size 8. |
|
static String |
expand(String self,
int tabStop)
Expands all tabs into spaces. |
|
static CharSequence |
expandLine(CharSequence self,
int tabStop)
Expands all tabs into spaces. |
|
static String |
expandLine(String self,
int tabStop)
Expands all tabs into spaces. |
|
static Writable |
filterLine(File self,
Closure closure)
Filters the lines of a File and creates a Writable in return to stream the filtered lines. |
|
static Writable |
filterLine(File self,
String charset,
Closure closure)
Filters the lines of a File and creates a Writable in return to stream the filtered lines. |
|
static void |
filterLine(File self,
Writer writer,
Closure closure)
Filter the lines from this File, and write them to the given writer based on the given closure predicate. |
|
static void |
filterLine(File self,
Writer writer,
String charset,
Closure closure)
Filter the lines from this File, and write them to the given writer based on the given closure predicate. |
|
static Writable |
filterLine(InputStream self,
Closure predicate)
Filter lines from an input stream using a closure predicate. |
|
static Writable |
filterLine(InputStream self,
String charset,
Closure predicate)
Filter lines from an input stream using a closure predicate. |
|
static void |
filterLine(InputStream self,
Writer writer,
Closure predicate)
Uses a closure to filter lines from this InputStream and pass them to the given writer. |
|
static void |
filterLine(InputStream self,
Writer writer,
String charset,
Closure predicate)
Uses a closure to filter lines from this InputStream and pass them to the given writer. |
|
static Writable |
filterLine(Reader reader,
Closure closure)
Filter the lines from this Reader, and return a Writable which can be used to stream the filtered lines to a destination. |
|
static void |
filterLine(Reader reader,
Writer writer,
Closure closure)
Filter the lines from a reader and write them on the writer, according to a closure which returns true if the line should be included. |
|
static Writable |
filterLine(URL self,
Closure predicate)
Filter lines from a URL using a closure predicate. |
|
static Writable |
filterLine(URL self,
String charset,
Closure predicate)
Filter lines from a URL using a closure predicate. |
|
static void |
filterLine(URL self,
Writer writer,
Closure predicate)
Uses a closure to filter lines from this URL and pass them to the given writer. |
|
static void |
filterLine(URL self,
Writer writer,
String charset,
Closure predicate)
Uses a closure to filter lines from this URL and pass them to the given writer. |
|
static CharSequence |
find(CharSequence self,
CharSequence regex)
Finds the first occurrence of a regular expression CharSequence within a CharSequence. |
|
static CharSequence |
find(CharSequence self,
CharSequence regex,
Closure closure)
Returns the result of calling a closure with the first occurrence of a regular expression found within a CharSequence. |
|
static CharSequence |
find(CharSequence self,
Pattern pattern)
Finds the first occurrence of a compiled regular expression Pattern within a CharSequence. |
|
static CharSequence |
find(CharSequence self,
Pattern pattern,
Closure closure)
|
|
static
|
find(Collection<T> self)
Finds the first item matching the IDENTITY Closure (i.e. |
|
static
|
find(Collection<T> self,
Closure closure)
Finds the first value matching the closure condition. |
|
static
|
find(Map<K,V> self,
Closure<?> closure)
Finds the first entry matching the closure condition. |
|
static Object |
find(Object self)
Finds the first item matching the IDENTITY Closure (i.e. |
|
static Object |
find(Object self,
Closure closure)
Finds the first value matching the closure condition |
|
static String |
find(String self,
Pattern pattern)
Finds the first occurrence of a compiled regular expression Pattern within a String. |
|
static String |
find(String self,
Pattern pattern,
Closure closure)
Returns the result of calling a closure with the first occurrence of a compiled regular expression found within a String. |
|
static String |
find(String self,
String regex)
Finds the first occurrence of a regular expression String within a String. |
|
static String |
find(String self,
String regex,
Closure closure)
Returns the result of calling a closure with the first occurrence of a regular expression found within a String. |
|
static List<CharSequence> |
findAll(CharSequence self,
CharSequence regex)
Returns a (possibly empty) list of all occurrences of a regular expression (in CharSequence format) found within a CharSequence. |
|
static
|
findAll(CharSequence self,
CharSequence regex,
Closure<T> closure)
Finds all occurrences of a capturing regular expression CharSequence within a CharSequence. |
|
static List<CharSequence> |
findAll(CharSequence self,
Pattern pattern)
Returns a (possibly empty) list of all occurrences of a regular expression (in Pattern format) found within a CharSequence. |
|
static
|
findAll(CharSequence self,
Pattern pattern,
Closure<T> closure)
Finds all occurrences of a compiled regular expression Pattern within a CharSequence. |
|
static
|
findAll(Collection<T> self)
Finds the items matching the IDENTITY Closure (i.e. |
|
static
|
findAll(Collection<T> self,
Closure closure)
Finds all values matching the closure condition. |
|
static
|
findAll(Map<K,V> self,
Closure closure)
Finds all entries matching the closure condition. |
|
static Collection |
findAll(Object self)
Finds all items matching the IDENTITY Closure (i.e. |
|
static Collection |
findAll(Object self,
Closure closure)
Finds all items matching the closure condition. |
|
static List<String> |
findAll(String self,
Pattern pattern)
Returns a (possibly empty) list of all occurrences of a regular expression (in Pattern format) found within a String. |
|
static
|
findAll(String self,
Pattern pattern,
Closure<T> closure)
Finds all occurrences of a compiled regular expression Pattern within a String. |
|
static List<String> |
findAll(String self,
String regex)
Returns a (possibly empty) list of all occurrences of a regular expression (in String format) found within a String. |
|
static
|
findAll(String self,
String regex,
Closure<T> closure)
Finds all occurrences of a regular expression string within a String. |
|
static int |
findIndexOf(Object self,
Closure closure)
Iterates over the elements of an iterable collection of items and returns the index of the first item that matches the condition specified in the closure. |
|
static int |
findIndexOf(Object self,
int startIndex,
Closure closure)
Iterates over the elements of an iterable collection of items, starting from a specified startIndex, and returns the index of the first item that matches the condition specified in the closure. |
|
static List<Number> |
findIndexValues(Object self,
Closure closure)
Iterates over the elements of an iterable collection of items and returns the index values of the items that match the condition specified in the closure. |
|
static List<Number> |
findIndexValues(Object self,
Number startIndex,
Closure closure)
Iterates over the elements of an iterable collection of items, starting from a specified startIndex, and returns the index values of the items that match the condition specified in the closure. |
|
static int |
findLastIndexOf(Object self,
Closure closure)
Iterates over the elements of an iterable collection of items and returns the index of the last item that matches the condition specified in the closure. |
|
static int |
findLastIndexOf(Object self,
int startIndex,
Closure closure)
Iterates over the elements of an iterable collection of items, starting from a specified startIndex, and returns the index of the last item that matches the condition specified in the closure. |
|
static
|
findResult(Collection<?> self,
Closure<T> closure)
Iterates through the collection calling the given closure for each item but stopping once the first non-null result is found and returning that result. |
|
static
|
findResult(Collection<?> self,
U defaultResult,
Closure<V> closure)
Iterates through the collection calling the given closure for each item but stopping once the first non-null result is found and returning that result. |
|
static
|
findResult(Map<?,?> self,
Closure<T> closure)
Returns the first non-null closure result found by passing each map entry to the closure, otherwise null is returned. |
|
static
|
findResult(Map<?,?> self,
U defaultResult,
Closure<V> closure)
Returns the first non-null closure result found by passing each map entry to the closure, otherwise the defaultResult is returned. |
|
static Object |
findResult(Object self,
Closure closure)
Treats the object as iterable, iterating through the values it represents and returns the first non-null result obtained from calling the closure, otherwise returns null. |
|
static Object |
findResult(Object self,
Object defaultResult,
Closure closure)
Treats the object as iterable, iterating through the values it represents and returns the first non-null result obtained from calling the closure, otherwise returns the defaultResult. |
|
static
|
findResults(Collection<?> self,
Closure<T> filteringTransform)
Iterates through the collection transforming items using the supplied closure and collecting any non-null results. |
|
static
|
findResults(Map<?,?> self,
Closure<T> filteringTransform)
Iterates through the map transforming items using the supplied closure and collecting any non-null results. |
|
static
|
first(Iterable<T> self)
Returns the first item from the Iterable. |
|
static
|
first(List<T> self)
Returns the first item from the List. |
|
static
|
first(T[] self)
Returns the first item from the array. |
|
static Collection |
flatten(boolean[] self)
Flatten an array. |
|
static Collection |
flatten(byte[] self)
Flatten an array. |
|
static Collection |
flatten(char[] self)
Flatten an array. |
|
static Collection<?> |
flatten(Collection<?> self)
Flatten a collection. |
|
static
|
flatten(Collection<T> self,
Closure<? extends T> flattenUsing)
Flatten a collection. |
|
static Collection |
flatten(double[] self)
Flatten an array. |
|
static Collection |
flatten(float[] self)
Flatten an array. |
|
static Collection |
flatten(int[] self)
Flatten an array. |
|
static Collection |
flatten(long[] self)
Flatten an array. |
|
static Collection |
flatten(Object[] self)
Flatten an array. |
|
static Collection |
flatten(short[] self)
Flatten an array. |
|
static
|
get(Map<K,V> map,
K key,
V defaultValue)
Looks up an item in a Map for the given key and returns the value - unless there is no entry for the given key in which case add the default value to the map and return that. |
|
static boolean |
getAt(BitSet self,
int index)
Support the subscript operator for a Bitset |
|
static BitSet |
getAt(BitSet self,
IntRange range)
Support retrieving a subset of a BitSet using a Range |
|
static List<Boolean> |
getAt(boolean[] array,
Collection indices)
Support the subscript operator with a collection for a boolean array |
|
static List<Boolean> |
getAt(boolean[] array,
IntRange range)
Support the subscript operator with an IntRange for a boolean array |
|
static List<Boolean> |
getAt(boolean[] array,
ObjectRange range)
Support the subscript operator with an ObjectRange for a byte array |
|
static List<Boolean> |
getAt(boolean[] array,
Range range)
Support the subscript operator with a range for a boolean array |
|
static List<Byte> |
getAt(byte[] array,
Collection indices)
Support the subscript operator with a collection for a byte array |
|
static List<Byte> |
getAt(byte[] array,
IntRange range)
Support the subscript operator with an IntRange for a byte array |
|
static List<Byte> |
getAt(byte[] array,
ObjectRange range)
Support the subscript operator with an ObjectRange for a byte array |
|
static List<Byte> |
getAt(byte[] array,
Range range)
Support the subscript operator with a range for a byte array |
|
static List<Character> |
getAt(char[] array,
Collection indices)
Support the subscript operator with a collection for a char array |
|
static List<Character> |
getAt(char[] array,
IntRange range)
Support the subscript operator with an IntRange for a char array |
|
static List<Character> |
getAt(char[] array,
ObjectRange range)
Support the subscript operator with an ObjectRange for a char array |
|
static List<Character> |
getAt(char[] array,
Range range)
Support the subscript operator with a range for a char array |
|
static CharSequence |
getAt(CharSequence self,
Collection indices)
Select a List of characters from a CharSequence using a Collection to identify the indices to be selected. |
|
static CharSequence |
getAt(CharSequence text,
EmptyRange range)
Support the range subscript operator for CharSequence or StringBuffer with EmptyRange |
|
static CharSequence |
getAt(CharSequence text,
int index)
Support the subscript operator for CharSequence. |
|
static CharSequence |
getAt(CharSequence text,
IntRange range)
Support the range subscript operator for CharSequence or StringBuffer with IntRange |
|
static CharSequence |
getAt(CharSequence text,
Range range)
Support the range subscript operator for CharSequence |
|
static List |
getAt(Collection coll,
String property)
Support the subscript operator for Collection. |
|
static List<Double> |
getAt(double[] array,
Collection indices)
Support the subscript operator with a collection for a double array |
|
static List<Double> |
getAt(double[] array,
IntRange range)
Support the subscript operator with an IntRange for a double array |
|
static List<Double> |
getAt(double[] array,
ObjectRange range)
Support the subscript operator with an ObjectRange for a double array |
|
static List<Double> |
getAt(double[] array,
Range range)
Support the subscript operator with a range for a double array |
|
static List<Float> |
getAt(float[] array,
Collection indices)
Support the subscript operator with a collection for a float array |
|
static List<Float> |
getAt(float[] array,
IntRange range)
Support the subscript operator with an IntRange for a float array |
|
static List<Float> |
getAt(float[] array,
ObjectRange range)
Support the subscript operator with an ObjectRange for a float array |
|
static List<Float> |
getAt(float[] array,
Range range)
Support the subscript operator with a range for a float array |
|
static List<Integer> |
getAt(int[] array,
Collection indices)
Support the subscript operator with a collection for an int array |
|
static List<Integer> |
getAt(int[] array,
IntRange range)
Support the subscript operator with an IntRange for an int array |
|
static List<Integer> |
getAt(int[] array,
ObjectRange range)
Support the subscript operator with an ObjectRange for an int array |
|
static List<Integer> |
getAt(int[] array,
Range range)
Support the subscript operator with a range for an int array |
|
static
|
getAt(Iterator<T> self,
int idx)
Support the subscript operator for an Iterator. |
|
static
|
getAt(List<T> self,
Collection indices)
Select a List of items from a List using a Collection to identify the indices to be selected. |
|
static
|
getAt(List<T> self,
EmptyRange range)
Support the range subscript operator for a List. |
|
static
|
getAt(List<T> self,
int idx)
Support the subscript operator for a List. |
|
static
|
getAt(List<T> self,
Range range)
Support the range subscript operator for a List. |
|
static List<Long> |
getAt(long[] array,
Collection indices)
Support the subscript operator with a collection for a long array |
|
static List<Long> |
getAt(long[] array,
IntRange range)
Support the subscript operator with an IntRange for a long array |
|
static List<Long> |
getAt(long[] array,
ObjectRange range)
Support the subscript operator with an ObjectRange for a long array |
|
static List<Long> |
getAt(long[] array,
Range range)
Support the subscript operator with a range for a long array |
|
static
|
getAt(Map<K,V> self,
K key)
Support the subscript operator for a Map. |
|
static List |
getAt(Matcher self,
Collection indices)
Select a List of values from a Matcher using a Collection to identify the indices to be selected. |
|
static Object |
getAt(Matcher matcher,
int idx)
Support the subscript operator, e.g. |
|
static Object |
getAt(Object self,
String property)
Allows the subscript operator to be used to lookup dynamic property values. |
|
static List<Short> |
getAt(short[] array,
Collection indices)
Support the subscript operator with a collection for a short array |
|
static List<Short> |
getAt(short[] array,
IntRange range)
Support the subscript operator with an IntRange for a short array |
|
static List<Short> |
getAt(short[] array,
ObjectRange range)
Support the subscript operator with an ObjectRange for a short array |
|
static List<Short> |
getAt(short[] array,
Range range)
Support the subscript operator with a range for a short array |
|
static String |
getAt(String self,
Collection indices)
Select a List of characters from a String using a Collection to identify the indices to be selected. |
|
static String |
getAt(String text,
EmptyRange range)
Support the range subscript operator for String with EmptyRange |
|
static String |
getAt(String text,
int index)
Support the subscript operator for String. |
|
static String |
getAt(String text,
IntRange range)
Support the range subscript operator for String with IntRange |
|
static String |
getAt(String text,
Range range)
Support the range subscript operator for String |
|
static
|
getAt(T[] self,
Collection indices)
Select a List of items from an Object array using a Collection to identify the indices to be selected. |
|
static
|
getAt(T[] array,
EmptyRange range)
|
|
static
|
getAt(T[] array,
IntRange range)
|
|
static
|
getAt(T[] array,
ObjectRange range)
|
|
static
|
getAt(T[] array,
Range range)
Support the range subscript operator for an Array |
|
static byte[] |
getBytes(File file)
Read the content of the File and returns it as a byte[]. |
|
static byte[] |
getBytes(InputStream is)
Read the content of this InputStream and return it as a byte[]. |
|
static byte[] |
getBytes(URL url)
Read the content of this URL and returns it as a byte[]. |
|
static char[] |
getChars(CharSequence self)
Converts the given CharSequence into an array of characters. |
|
static char[] |
getChars(String self)
Converts the given String into an array of characters. |
|
static int |
getCount(Matcher matcher)
Find the number of Strings matched to the given Matcher. |
|
static MetaClass |
getMetaClass(Class c)
Adds a "metaClass" property to all class objects so you can use the syntax String.metaClass.myMethod = { println "foo" } |
|
static MetaClass |
getMetaClass(GroovyObject obj)
Obtains a MetaClass for an object either from the registry or in the case of a GroovyObject from the object itself. |
|
static MetaClass |
getMetaClass(Object obj)
Obtains a MetaClass for an object either from the registry or in the case of a GroovyObject from the object itself. |
|
static List<PropertyValue> |
getMetaPropertyValues(Object self)
Retrieves the list of MetaProperty objects for 'self' and wraps it
in a list of PropertyValue objects that additionally provide
the value for each property of 'self'. |
|
static Map |
getProperties(Object self)
Convenience method that calls getMetaPropertyValues(java.lang.Object) (self)
and provides the data in form of simple key/value pairs, i.e. |
|
static ClassLoader |
getRootLoader(ClassLoader self)
Iterates through the classloader parents until it finds a loader with a class named "org.codehaus.groovy.tools.RootLoader". |
|
protected static List |
getSubList(List self,
List splice)
|
|
static String |
getText(BufferedReader reader)
Read the content of the BufferedReader and return it as a String. |
|
static String |
getText(File file)
Read the content of the File and returns it as a String. |
|
static String |
getText(File file,
String charset)
Read the content of the File using the specified encoding and return it as a String. |
|
static String |
getText(InputStream is)
Read the content of this InputStream and return it as a String. |
|
static String |
getText(InputStream is,
String charset)
Read the content of this InputStream using specified charset and return it as a String. |
|
static String |
getText(Reader reader)
Read the content of the Reader and return it as a String. |
|
static String |
getText(URL url)
Read the content of this URL and returns it as a String. |
|
static String |
getText(URL url,
Map parameters)
Read the content of this URL and returns it as a String. |
|
static String |
getText(URL url,
Map parameters,
String charset)
Read the data from this URL and return it as a String. |
|
static String |
getText(URL url,
String charset)
Read the data from this URL and return it as a String. |
|
static Collection |
grep(Object self)
Iterates over the collection of items which this Object represents and returns each item that matches using the IDENTITY Closure as a filter - effectively returning all elements which satisfy Groovy truth. |
|
static Collection |
grep(Object self,
Object filter)
Iterates over the collection of items which this Object represents and returns each item that matches the given filter - calling the
method used by switch statements. |
|
protected static
|
groupAnswer(Map<K,List<T>> answer,
T element,
K value)
Groups the current element according to the value |
|
static
|
groupBy(Collection<T> self,
Closure<K> closure)
Sorts all collection members into groups determined by the supplied mapping closure. |
|
static Map |
groupBy(Collection self,
List<Closure> closures)
Sorts all collection members into (sub)groups determined by the supplied mapping closures. |
|
static Map |
groupBy(Collection self,
Object... closures)
Sorts all collection members into (sub)groups determined by the supplied mapping closures. |
|
static
|
groupBy(Map<K,V> self,
Closure<G> closure)
Groups the members of a map into sub maps determined by the supplied mapping closure. |
|
static Map<Object,Map> |
groupBy(Map self,
List<Closure> closures)
Groups the members of a map into sub maps determined by the supplied mapping closures. |
|
static Map<Object,Map> |
groupBy(Map self,
Object... closures)
Groups the members of a map into sub maps determined by the supplied mapping closures. |
|
static
|
groupEntriesBy(Map<K,V> self,
Closure<G> closure)
Groups all map entries into groups determined by the supplied mapping closure. |
|
static boolean |
hasGroup(Matcher matcher)
Check whether a Matcher contains a group or not. |
|
static MetaProperty |
hasProperty(Object self,
String name)
Returns true of the implementing MetaClass has a property of the given name Note that this method will only return true for realised properties and does not take into account implementation of getProperty or propertyMissing |
|
static
|
head(List<T> self)
Returns the first item from the List. |
|
static
|
head(T[] self)
Returns the first item from the Object array. |
|
static
|
identity(Object self,
Closure<T> closure)
Allows the closure to be called for the object reference self. |
|
static Boolean |
implies(Boolean left,
Boolean right)
Logical implication of two boolean operators |
|
static
|
inject(Collection<T> self,
Closure<V> closure)
Performs the same function as the version of inject that takes an initial value, but uses the head of the Collection as the initial value, and iterates over the tail. |
|
static
|
inject(Collection self,
U initialValue,
Closure<V> closure)
Iterates through the given Collection, passing in the initial value to the 2-arg closure along with the first item. |
|
static
|
inject(Iterator self,
U initialValue,
Closure<V> closure)
Iterates through the given Iterator, passing in the initial value to the closure along with the first item. |
|
static
|
inject(Map<?,?> self,
U initialValue,
Closure<V> closure)
Iterates through the given Map, passing in the initial value to the 2-arg Closure along with the first item (or 3-arg Closure along with the first key and value). |
|
static
|
inject(Object[] self,
Closure<V> closure)
Iterates through the given array as with inject(Object[],initialValue,closure), but using the first element of the array as the initialValue, and then iterating the remaining elements of the array. |
|
static
|
inject(Object[] self,
U initialValue,
Closure<V> closure)
Iterates through the given array, passing in the initial value to the closure along with the first item. |
|
static
|
inject(Object self,
Closure<V> closure)
Iterates through the given Object, passing in the first value to the closure along with the first item. |
|
static
|
inject(Object self,
U initialValue,
Closure<V> closure)
Iterates through the given Object, passing in the initial value to the closure along with the first item. |
|
static String |
inspect(Object self)
Inspects returns the String that matches what would be typed into a terminal to create this object. |
|
static Number |
intdiv(Character left,
Character right)
Integer Divide two Characters. |
|
static Number |
intdiv(Character left,
Number right)
Integer Divide a Character by a Number. |
|
static Number |
intdiv(Number left,
Character right)
Integer Divide a Number by a Character. |
|
static Number |
intdiv(Number left,
Number right)
Integer Divide two Numbers. |
|
static
|
intersect(Collection<T> left,
Collection<T> right)
Create a Collection composed of the intersection of both collections. |
|
static
|
intersect(Map<K,V> left,
Map<K,V> right)
Create a Map composed of the intersection of both maps. |
|
static Object |
invokeMethod(Object object,
String method,
Object arguments)
Provide a dynamic method invocation method which can be overloaded in classes to implement dynamic proxies easily. |
|
static boolean |
is(Object self,
Object other)
Identity check. |
|
static boolean |
isAllWhitespace(CharSequence self)
True if a CharSequence only contains whitespace characters. |
|
static boolean |
isAllWhitespace(String self)
True if a String only contains whitespace characters. |
|
static boolean |
isBigDecimal(CharSequence self)
Determine if a CharSequence can be parsed as a BigDecimal. |
|
static boolean |
isBigDecimal(String self)
Determine if a String can be parsed into a BigDecimal. |
|
static boolean |
isBigInteger(CharSequence self)
Determine if a CharSequence can be parsed as a BigInteger. |
|
static boolean |
isBigInteger(String self)
Determine if a String can be parsed into a BigInteger. |
|
static boolean |
isCase(CharSequence caseValue,
Object switchValue)
'Case' implementation for a CharSequence, which simply calls the equivalent method for String. |
|
static boolean |
isCase(Class caseValue,
Object switchValue)
Special 'Case' implementation for Class, which allows testing for a certain class in a switch statement. |
|
static boolean |
isCase(Collection caseValue,
Object switchValue)
'Case' implementation for collections which tests if the 'switch' operand is contained in any of the 'case' values. |
|
static boolean |
isCase(GString caseValue,
Object switchValue)
'Case' implementation for a GString, which simply calls the equivalent method for String. |
|
static boolean |
isCase(Map caseValue,
Object switchValue)
'Case' implementation for maps which tests the groovy truth value obtained using the 'switch' operand as key. |
|
static boolean |
isCase(Number caseValue,
Number switchValue)
Special 'case' implementation for all numbers, which delegates to the compareTo() method for comparing numbers of different
types. |
|
static boolean |
isCase(Object caseValue,
Object switchValue)
Method for overloading the behavior of the 'case' method in switch statements. |
|
static boolean |
isCase(Pattern caseValue,
Object switchValue)
'Case' implementation for the Pattern class, which allows
testing a String against a number of regular expressions. |
|
static boolean |
isCase(String caseValue,
Object switchValue)
'Case' implementation for a String, which uses String#equals(Object) in order to allow Strings to be used in switch statements. |
|
static boolean |
isDigit(Character self)
Determines if a character is a digit. |
|
static boolean |
isDouble(CharSequence self)
Determine if a CharSequence can be parsed as a Double. |
|
static boolean |
isDouble(String self)
Determine if a String can be parsed into a Double. |
|
static boolean |
isFloat(CharSequence self)
Determine if a CharSequence can be parsed as a Float. |
|
static boolean |
isFloat(String self)
Determine if a String can be parsed into a Float. |
|
static boolean |
isInteger(CharSequence self)
Determine if a CharSequence can be parsed as an Integer. |
|
static boolean |
isInteger(String self)
Determine if a String can be parsed into an Integer. |
|
static boolean |
isLetter(Character self)
Determines if a character is a letter. |
|
static boolean |
isLetterOrDigit(Character self)
Determines if a character is a letter or digit. |
|
static boolean |
isLong(CharSequence self)
Determine if a CharSequence can be parsed as a Long. |
|
static boolean |
isLong(String self)
Determine if a String can be parsed into a Long. |
|
static boolean |
isLowerCase(Character self)
Determine if a Character is lowercase. |
|
static boolean |
isNumber(CharSequence self)
Determine if a CharSequence can be parsed as a Number. |
|
static boolean |
isNumber(String self)
Determine if a String can be parsed into a Number. |
|
static boolean |
isUpperCase(Character self)
Determine if a Character is uppercase. |
|
static boolean |
isWhitespace(Character self)
Determines if a character is a whitespace character. |
|
static Iterator<Byte> |
iterator(DataInputStream self)
Standard iterator for a data input stream which iterates through the stream content a Byte at a time. |
|
static
|
iterator(Enumeration<T> enumeration)
Allows an Enumeration to behave like an Iterator. |
|
static Iterator<Byte> |
iterator(InputStream self)
Standard iterator for a input stream which iterates through the stream content in a byte-based fashion. |
|
static
|
iterator(Iterator<T> self)
An identity function for iterators, supporting 'duck-typing' when trying to get an iterator for each object within a collection, some of which may already be iterators. |
|
static Iterator |
iterator(Matcher matcher)
Returns an Iterator which traverses each match. |
|
static Iterator |
iterator(Object o)
Attempts to create an Iterator for the given object by first converting it to a Collection. |
|
static Iterator<String> |
iterator(Reader self)
Creates an iterator which will traverse through the reader a line at a time. |
|
static
|
iterator(T[] a)
Attempts to create an Iterator for the given object by first converting it to a Collection. |
|
static String |
join(Collection self,
String separator)
Concatenates the toString() representation of each
item in this collection, with the given String as a separator between
each item. |
|
static String |
join(Iterator<Object> self,
String separator)
Concatenates the toString() representation of each
item from the iterator, with the given String as a separator between
each item. |
|
static String |
join(Object[] self,
String separator)
Concatenates the toString() representation of each
items in this array, with the given String as a separator between each
item. |
|
static
|
last(Iterable<T> self)
Returns the last item from the Iterable. |
|
static
|
last(List<T> self)
Returns the last item from the List. |
|
static
|
last(T[] self)
Returns the last item from the array. |
|
static
|
leftShift(BlockingQueue<T> self,
T value)
Overloads the left shift operator to provide an easy way to append objects to a BlockingQueue. |
|
static StringBuilder |
leftShift(CharSequence self,
Object value)
Overloads the left shift operator to provide an easy way to append multiple objects as string representations to a CharSequence. |
|
static
|
leftShift(Collection<T> self,
T value)
Overloads the left shift operator to provide an easy way to append objects to a Collection. |
|
static File |
leftShift(File file,
byte[] bytes)
Write bytes to a File. |
|
static File |
leftShift(File file,
InputStream data)
Append binary data to the file. |
|
static File |
leftShift(File file,
Object text)
Write the text to the File. |
|
static
|
leftShift(Map<K,V> self,
Map.Entry<K,V> entry)
Overloads the left shift operator to provide an easy way to append Map.Entry values to a Map. |
|
static
|
leftShift(Map<K,V> self,
Map<K,V> other)
Overloads the left shift operator to provide an easy way to put one maps entries into another map. |
|
static Number |
leftShift(Number self,
Number operand)
Implementation of the left shift operator for integral types. |
|
static void |
leftShift(ObjectOutputStream self,
Object value)
Overloads the leftShift operator to add objects to an ObjectOutputStream. |
|
static OutputStream |
leftShift(OutputStream self,
byte[] value)
Overloads the leftShift operator to provide an append mechanism to add bytes to a stream. |
|
static OutputStream |
leftShift(OutputStream self,
InputStream in)
Pipe an InputStream into an OutputStream for efficient stream copying. |
|
static Writer |
leftShift(OutputStream self,
Object value)
Overloads the leftShift operator to provide an append mechanism to add values to a stream. |
|
static OutputStream |
leftShift(Socket self,
byte[] value)
Overloads the left shift operator to provide an append mechanism to add bytes to the output stream of a socket |
|
static Writer |
leftShift(Socket self,
Object value)
Overloads the left shift operator to provide an append mechanism to add things to the output stream of a socket |
|
static StringBuffer |
leftShift(StringBuffer self,
Object value)
Overloads the left shift operator to provide an easy way to append multiple objects as string representations to a StringBuffer. |
|
static StringBuilder |
leftShift(StringBuilder self,
Object value)
Overloads the left shift operator to provide syntactic sugar for appending to a StringBuilder. |
|
static StringBuffer |
leftShift(String self,
Object value)
Overloads the left shift operator to provide an easy way to append multiple objects as string representations to a String. |
|
static Writer |
leftShift(Writer self,
Object value)
Overloads the left shift operator to provide a mechanism to append values to a writer. |
|
static boolean |
matches(CharSequence self,
Pattern pattern)
Tells whether or not a CharSequence matches the given compiled regular expression Pattern. |
|
static boolean |
matches(String self,
Pattern pattern)
Tells whether or not self matches the given compiled regular expression Pattern. |
|
static
|
max(Collection<T> self)
Adds max() method to Collection objects. |
|
static
|
max(Collection<T> self,
Closure closure)
Selects an item in the collection having the maximum value as determined by the supplied closure. |
|
static
|
max(Collection<T> self,
Comparator<T> comparator)
Selects the maximum value found in the collection using the given comparator. |
|
static
|
max(Iterator<T> self)
Adds max() method to Iterator objects. |
|
static
|
max(Iterator<T> self,
Closure closure)
Selects the maximum value found from the Iterator using the closure to determine the correct ordering. |
|
static
|
max(Iterator<T> self,
Comparator<T> comparator)
Selects the maximum value found from the Iterator using the given comparator. |
|
static
|
max(Map<K,V> self,
Closure closure)
Selects an entry in the map having the maximum calculated value as determined by the supplied closure. |
|
static
|
max(T[] self)
Adds max() method to Object arrays. |
|
static
|
max(T[] self,
Closure closure)
Selects the maximum value found from the Object array using the closure to determine the correct ordering. |
|
static
|
max(T[] self,
Comparator<T> comparator)
Selects the maximum value found from the Object array using the given comparator. |
|
static MetaClass |
metaClass(Class self,
Closure closure)
Sets/updates the metaclass for a given class to a closure. |
|
static MetaClass |
metaClass(Object self,
Closure closure)
Sets/updates the metaclass for a given object to a closure. |
|
static
|
min(Collection<T> self)
Adds min() method to Collection objects. |
|
static
|
min(Collection<T> self,
Closure closure)
Selects an item in the collection having the minimum value as determined by the supplied closure. |
|
static
|
min(Collection<T> self,
Comparator<T> comparator)
Selects the minimum value found in the collection using the given comparator. |
|
static
|
min(Iterator<T> self)
Adds min() method to Iterator objects. |
|
static
|
min(Iterator<T> self,
Closure closure)
Selects the minimum value found from the Iterator using the closure to determine the correct ordering. |
|
static
|
min(Iterator<T> self,
Comparator<T> comparator)
Selects the minimum value found from the Iterator using the given comparator. |
|
static
|
min(Map<K,V> self,
Closure closure)
Selects an entry in the map having the minimum calculated value as determined by the supplied closure. |
|
static
|
min(T[] self)
Adds min() method to Object arrays. |
|
static
|
min(T[] self,
Closure closure)
Selects the minimum value found from the Object array using the closure to determine the correct ordering. |
|
static
|
min(T[] self,
Comparator<T> comparator)
Selects the minimum value found from the Object array using the given comparator. |
|
static Number |
minus(Character left,
Character right)
Subtract one Character from another. |
|
static Number |
minus(Character left,
Number right)
Subtract a Number from a Character. |
|
static CharSequence |
minus(CharSequence self,
Object target)
Remove a part of a CharSequence by replacing the first occurrence of target within self with '' and returns the result. |
|
static
|
minus(List<T> self,
Collection<?> removeMe)
Create a List composed of the elements of the first list minus every occurrence of elements of the given Collection. |
|
static
|
minus(List<T> self,
Iterable<?> removeMe)
Create a List composed of the elements of the first list minus every occurrence of elements of the given Iterable. |
|
static
|
minus(List<T> self,
Object removeMe)
Create a new List composed of the elements of the first list minus every occurrence of the given element to remove. |
|
static
|
minus(Map<K,V> self,
Map removeMe)
Create a Map composed of the entries of the first map minus the entries of the given map. |
|
static Number |
minus(Number left,
Character right)
Subtract a Character from a Number. |
|
static
|
minus(Set<T> self,
Collection<?> removeMe)
Create a Set composed of the elements of the first Set minus the elements of the given Collection. |
|
static
|
minus(Set<T> self,
Iterable<?> removeMe)
Create a Set composed of the elements of the first Set minus the elements from the given Iterable. |
|
static
|
minus(Set<T> self,
Object removeMe)
Create a Set composed of the elements of the first Set minus the given element. |
|
static String |
minus(String self,
Object target)
Remove a part of a String. |
|
static
|
minus(T[] self,
Iterable removeMe)
Create an array composed of the elements of the first array minus the elements of the given Iterable. |
|
static
|
minus(T[] self,
Object removeMe)
Create a new object array composed of the elements of the first array minus the element to remove. |
|
static
|
minus(T[] self,
Object[] removeMe)
Create an array composed of the elements of the first array minus the elements of the given array. |
|
static void |
mixin(Class self,
Class categoryClass)
Extend class globally with category methods. |
|
static void |
mixin(Class self,
Class[] categoryClass)
Extend class globally with category methods. |
|
static void |
mixin(Class self,
List<Class> categoryClasses)
Extend class globally with category methods. |
|
static void |
mixin(MetaClass self,
Class categoryClass)
Extend class globally with category methods. |
|
static void |
mixin(MetaClass self,
Class[] categoryClass)
Extend class globally with category methods. |
|
static void |
mixin(MetaClass self,
List<Class> categoryClasses)
Extend object with category methods. |
|
static Number |
mod(Number left,
Number right)
Performs a division modulus operation. |
|
static Number |
multiply(BigDecimal left,
BigInteger right)
Multiply a BigDecimal and a BigInteger. |
|
static Number |
multiply(BigDecimal left,
Double right)
Multiply a BigDecimal and a Double. |
|
static Number |
multiply(Character left,
Character right)
Multiply two Characters. |
|
static Number |
multiply(Character left,
Number right)
Multiply a Character by a Number. |
|
static CharSequence |
multiply(CharSequence self,
Number factor)
Repeat a CharSequence a certain number of times. |
|
static
|
multiply(Collection<T> self,
Number factor)
Create a List composed of the elements of this list, repeated a certain number of times. |
|
static Number |
multiply(Number left,
Character right)
Multiply a Number by a Character. |
|
static String |
multiply(String self,
Number factor)
Repeat a String a certain number of times. |
|
static DataInputStream |
newDataInputStream(File file)
Create a data input stream for this file |
|
static DataOutputStream |
newDataOutputStream(File file)
Creates a new data output stream for this file. |
|
static BufferedInputStream |
newInputStream(File file)
Creates a buffered input stream for this file. |
|
static BufferedInputStream |
newInputStream(URL url)
Creates a buffered input stream for this URL. |
|
static BufferedInputStream |
newInputStream(URL url,
Map parameters)
Creates a buffered input stream for this URL. |
|
static
|
newInstance(Class<T> c)
Convenience method to dynamically create a new instance of this class. |
|
static
|
newInstance(Class<T> c,
Object[] args)
Helper to construct a new instance from the given arguments. |
|
static ObjectInputStream |
newObjectInputStream(File file)
Create an object input stream for this file. |
|
static ObjectInputStream |
newObjectInputStream(File file,
ClassLoader classLoader)
Create an object input stream for this file using the given class loader. |
|
static ObjectInputStream |
newObjectInputStream(InputStream inputStream)
Create an object input stream for this input stream. |
|
static ObjectInputStream |
newObjectInputStream(InputStream inputStream,
ClassLoader classLoader)
Create an object input stream for this input stream using the given class loader. |
|
static ObjectOutputStream |
newObjectOutputStream(File file)
Create an object output stream for this file. |
|
static ObjectOutputStream |
newObjectOutputStream(OutputStream outputStream)
Create an object output stream for this output stream. |
|
static BufferedOutputStream |
newOutputStream(File file)
Create a buffered output stream for this file. |
|
static PrintWriter |
newPrintWriter(File file)
Create a new PrintWriter for this file. |
|
static PrintWriter |
newPrintWriter(File file,
String charset)
Create a new PrintWriter for this file, using specified charset. |
|
static PrintWriter |
newPrintWriter(Writer writer)
Create a new PrintWriter for this file, using specified charset. |
|
static BufferedReader |
newReader(File file)
Create a buffered reader for this file. |
|
static BufferedReader |
newReader(File file,
String charset)
Create a buffered reader for this file, using the specified charset as the encoding. |
|
static BufferedReader |
newReader(InputStream self)
Creates a reader for this input stream. |
|
static BufferedReader |
newReader(InputStream self,
String charset)
Creates a reader for this input stream, using the specified charset as the encoding. |
|
static BufferedReader |
newReader(URL url)
Creates a buffered reader for this URL. |
|
static BufferedReader |
newReader(URL url,
Map parameters)
Creates a buffered reader for this URL. |
|
static BufferedReader |
newReader(URL url,
Map parameters,
String charset)
Creates a buffered reader for this URL using the given encoding. |
|
static BufferedReader |
newReader(URL url,
String charset)
Creates a buffered reader for this URL using the given encoding. |
|
static BufferedWriter |
newWriter(File file)
Create a buffered writer for this file. |
|
static BufferedWriter |
newWriter(File file,
boolean append)
Creates a buffered writer for this file, optionally appending to the existing file content. |
|
static BufferedWriter |
newWriter(File file,
String charset)
Creates a buffered writer for this file, writing data using the given encoding. |
|
static BufferedWriter |
newWriter(File file,
String charset,
boolean append)
Helper method to create a buffered writer for a file. |
|
static Character |
next(Character self)
Increment a Character by one. |
|
static CharSequence |
next(CharSequence self)
This method is called by the ++ operator for the class CharSequence. |
|
static Number |
next(Number self)
Increment a Number by one. |
|
static String |
next(String self)
This method is called by the ++ operator for the class String. |
|
static CharSequence |
normalize(CharSequence self)
Return a CharSequence with linefeeds and carriage returns normalized to linefeeds. |
|
static String |
normalize(String self)
Return a String with linefeeds and carriage returns normalized to linefeeds. |
|
static int |
numberAwareCompareTo(Comparable self,
Comparable other)
Provides a method that compares two comparables using Groovy's default number aware comparator. |
|
static BitSet |
or(BitSet left,
BitSet right)
Bitwise OR together two BitSets. |
|
static Boolean |
or(Boolean left,
Boolean right)
Logical disjunction of two boolean operators |
|
static Number |
or(Number left,
Number right)
Bitwise OR together two numbers. |
|
static CharSequence |
padLeft(CharSequence self,
Number numberOfChars)
Pad a CharSequence to a minimum length specified by numberOfChars by adding the space character to the left as many times as needed. |
|
static CharSequence |
padLeft(CharSequence self,
Number numberOfChars,
CharSequence padding)
Pad a CharSequence to a minimum length specified by numberOfChars, adding the supplied padding CharSequence as many times as needed to the left. |
|
static String |
padLeft(String self,
Number numberOfChars)
Pad a String to a minimum length specified by numberOfChars by adding the space character to the left as many times as needed. |
|
static String |
padLeft(String self,
Number numberOfChars,
String padding)
Pad a String to a minimum length specified by numberOfChars, adding the supplied padding String as many times as needed to the left. |
|
static CharSequence |
padRight(CharSequence self,
Number numberOfChars)
Pad a CharSequence to a minimum length specified by numberOfChars by adding the space character to the right as many times as needed. |
|
static CharSequence |
padRight(CharSequence self,
Number numberOfChars,
CharSequence padding)
Pad a CharSequence to a minimum length specified by numberOfChars, adding the supplied padding CharSequence as many times as needed to the right. |
|
static String |
padRight(String self,
Number numberOfChars)
Pad a String to a minimum length specified by numberOfChars by adding the space character to the right as many times as needed. |
|
static String |
padRight(String self,
Number numberOfChars,
String padding)
Pad a String to a minimum length specified by numberOfChars, adding the supplied padding String as many times as needed to the right. |
|
static
|
permutations(List<T> self)
Finds all permutations of a collection. |
|
static Number |
plus(Character left,
Character right)
Add one Character to another. |
|
static Number |
plus(Character left,
Number right)
Add a Character and a Number. |
|
static CharSequence |
plus(CharSequence left,
Object value)
Appends the String representation of the given operand to this string. |
|
static
|
plus(Collection<T> left,
Collection<T> right)
Create a Collection as a union of two collections. |
|
static
|
plus(Collection<T> left,
Iterable<T> right)
Create a Collection as a union of a Collection and an Iterable. |
|
static
|
plus(Collection<T> left,
T right)
Create a collection as a union of a Collection and an Object. |
|
static
|
plus(List<T> self,
int index,
Iterable<T> additions)
Creates a new List by inserting all of the elements in the given Iterable to the elements from this List at the specified index. |
|
static
|
plus(List<T> self,
int index,
List<T> additions)
Creates a new List by inserting all of the elements in the given additions List to the elements from the original List at the specified index. |
|
static
|
plus(List<T> self,
int index,
T[] items)
Creates a new List by inserting all of the elements in the specified array to the elements from the original List at the specified index. |
|
static
|
plus(Map<K,V> self,
Collection<Map.Entry<K,V>> entries)
Returns a new Map containing all entries from self and entries ,
giving precedence to entries . |
|
static
|
plus(Map<K,V> left,
Map<K,V> right)
Returns a new Map containing all entries from left and right ,
giving precedence to right . |
|
static Number |
plus(Number left,
Character right)
Add a Number and a Character. |
|
static String |
plus(Number value,
String right)
Appends a String to the string representation of this number. |
|
static String |
plus(StringBuffer left,
String value)
Appends a String to this StringBuffer. |
|
static String |
plus(String left,
Object value)
Appends the String representation of the given operand to this string. |
|
static
|
plus(T[] left,
Collection<T> right)
Create an array containing elements from an original array plus those from a Collection. |
|
static
|
plus(T[] left,
Iterable<T> right)
Create an array containing elements from an original array plus those from an Iterable. |
|
static
|
plus(T[] left,
T right)
Create an array containing elements from an original array plus an additional appended element. |
|
static
|
plus(T[] left,
T[] right)
Create an array as a union of two arrays. |
|
static
|
pop(List<T> self)
Removes the last item from the List. |
|
static Number |
power(BigDecimal self,
Integer exponent)
Power of a BigDecimal to an integer certain exponent. |
|
static Number |
power(BigInteger self,
Integer exponent)
Power of a BigInteger to an integer certain exponent. |
|
static Number |
power(Integer self,
Integer exponent)
Power of an integer to an integer certain exponent. |
|
static Number |
power(Long self,
Integer exponent)
Power of a long to an integer certain exponent. |
|
static Number |
power(Number self,
Number exponent)
Power of a Number to a certain exponent. |
|
static Character |
previous(Character self)
Decrement a Character by one. |
|
static CharSequence |
previous(CharSequence self)
This method is called by the -- operator for the class CharSequence. |
|
static Number |
previous(Number self)
Decrement a Number by one. |
|
static String |
previous(String self)
This method is called by the -- operator for the class String. |
|
protected static List |
primitiveArrayGet(Object self,
Collection indices)
Implements the getAt(Collection) method for primitive type arrays. |
|
protected static Object |
primitiveArrayGet(Object self,
int idx)
Implements the getAt(int) method for primitive type arrays. |
|
protected static List |
primitiveArrayGet(Object self,
Range range)
Implements the getAt(Range) method for primitive type arrays. |
|
protected static Object |
primitiveArrayPut(Object self,
int idx,
Object newValue)
Implements the setAt(int idx) method for primitive type arrays. |
|
static void |
print(Closure self,
Object value)
Print a value to the standard output stream. |
|
static void |
print(Object self,
Object value)
Print a value formatted Groovy style to self if it is a Writer, otherwise to the standard output stream. |
|
static void |
print(Object self,
PrintWriter out)
Print to a console in interactive format. |
|
static void |
print(PrintStream self,
Object value)
Print a value formatted Groovy style to the print stream. |
|
static void |
print(PrintWriter self,
Object value)
Print a value formatted Groovy style to the print writer. |
|
static void |
printf(Object self,
String format,
Object arg)
Prints a formatted string using the specified format string and arguments. |
|
static void |
printf(Object self,
String format,
Object[] values)
Printf to a console (Only works with JDK1.5 or later). |
|
static void |
println(Closure self)
Print a linebreak to the standard output stream. |
|
static void |
println(Closure self,
Object value)
Print a value (followed by a newline) to the standard output stream. |
|
static void |
println(Object self)
Print a linebreak to the standard output stream. |
|
static void |
println(Object self,
Object value)
Print a value formatted Groovy style (followed by a newline) to self if it is a Writer, otherwise to the standard output stream. |
|
static void |
println(Object self,
PrintWriter out)
Print to a console in interactive format. |
|
static void |
println(PrintStream self,
Object value)
Print a value formatted Groovy style (followed by a newline) to the print stream. |
|
static void |
println(PrintWriter self,
Object value)
Print a value formatted Groovy style (followed by a newline) to the print writer. |
|
static
|
push(List<T> self,
T value)
Appends an item to the List. |
|
static
|
putAll(Map<K,V> self,
Collection<Map.Entry<K,V>> entries)
Provides an easy way to append multiple Map.Entry values to a Map. |
|
static void |
putAt(BitSet self,
int index,
boolean value)
Support subscript-style assignment for a BitSet. |
|
static void |
putAt(BitSet self,
IntRange range,
boolean value)
Support assigning a range of values with a single assignment statement. |
|
static
|
putAt(List<T> self,
int idx,
T value)
A helper method to allow lists to work with subscript operators. |
|
static void |
putAt(List self,
EmptyRange range,
Collection value)
A helper method to allow lists to work with subscript operators. |
|
static void |
putAt(List self,
EmptyRange range,
Object value)
A helper method to allow lists to work with subscript operators. |
|
static void |
putAt(List self,
IntRange range,
Collection col)
List subscript assignment operator when given a range as the index and the assignment operand is a collection. |
|
static void |
putAt(List self,
IntRange range,
Object value)
List subscript assignment operator when given a range as the index. |
|
static void |
putAt(List self,
List splice,
List values)
A helper method to allow lists to work with subscript operators. |
|
static void |
putAt(List self,
List splice,
Object value)
A helper method to allow lists to work with subscript operators. |
|
static
|
putAt(Map<K,V> self,
K key,
V value)
A helper method to allow maps to work with subscript operators |
|
static void |
putAt(Object self,
String property,
Object newValue)
Allows the subscript operator to be used to set dynamically named property values. |
|
static void |
putAt(StringBuffer self,
EmptyRange range,
Object value)
Support the range subscript operator for StringBuffer. |
|
static void |
putAt(StringBuffer self,
IntRange range,
Object value)
Support the range subscript operator for StringBuffer. |
|
static byte[] |
readBytes(File file)
Reads the content of the file into a byte array. |
|
static String |
readLine(Reader self)
Read a single, whole line from the given Reader. |
|
static List<CharSequence> |
readLines(CharSequence self)
Return the lines of a CharSequence as a List of CharSequence. |
|
static List<String> |
readLines(File file)
Reads the file into a list of Strings, with one item for each line. |
|
static List<String> |
readLines(File file,
String charset)
Reads the file into a list of Strings, with one item for each line. |
|
static List<String> |
readLines(InputStream stream)
Reads the stream into a list, with one element for each line. |
|
static List<String> |
readLines(InputStream stream,
String charset)
Reads the stream into a list, with one element for each line. |
|
static List<String> |
readLines(Reader reader)
Reads the reader into a list of Strings, with one entry for each line. |
|
static List<String> |
readLines(String self)
Return the lines of a String as a List of Strings. |
|
static List<String> |
readLines(URL self)
Reads the URL contents into a list, with one element for each line. |
|
static List<String> |
readLines(URL self,
String charset)
Reads the URL contents into a list, with one element for each line. |
|
static boolean |
removeAll(Collection self,
Closure condition)
Modifies this collection by removing the elements that are matched according to the specified closure condition. |
|
static boolean |
removeAll(Collection self,
Object[] items)
Modifies this collection by removing its elements that are contained within the specified object array. |
|
static boolean |
renameTo(File self,
String newPathName)
Renames the file. |
|
static CharSequence |
replaceAll(CharSequence self,
CharSequence regex,
CharSequence replacement)
Replaces each substring of this CharSequence that matches the given regular expression with the given replacement. |
|
static CharSequence |
replaceAll(CharSequence self,
CharSequence regex,
Closure closure)
Replaces all occurrences of a captured group by the result of a closure on that text. |
|
static CharSequence |
replaceAll(CharSequence self,
Pattern pattern,
CharSequence replacement)
Replaces all substrings of a CharSequence that match the given compiled regular expression with the given replacement. |
|
static String |
replaceAll(CharSequence self,
Pattern pattern,
Closure closure)
Replaces all occurrences of a captured group by the result of a closure call on that text. |
|
static String |
replaceAll(String self,
Pattern pattern,
Closure closure)
Replaces all occurrences of a captured group by the result of a closure call on that text. |
|
static String |
replaceAll(String self,
Pattern pattern,
String replacement)
Replaces all substrings of a String that match the given compiled regular expression with the given replacement. |
|
static String |
replaceAll(String self,
String regex,
Closure closure)
Replaces all occurrences of a captured group by the result of a closure on that text. |
|
static String |
replaceFirst(CharSequence self,
CharSequence regex,
CharSequence replacement)
Replaces the first substring of this CharSequence that matches the given regular expression with the given replacement. |
|
static String |
replaceFirst(CharSequence self,
CharSequence regex,
Closure closure)
Replaces the first occurrence of a captured group by the result of a closure call on that text. |
|
static CharSequence |
replaceFirst(CharSequence self,
Pattern pattern,
CharSequence replacement)
Replaces the first substring of a CharSequence that matches the given compiled regular expression with the given replacement. |
|
static String |
replaceFirst(CharSequence self,
Pattern pattern,
Closure closure)
Replaces the first occurrence of a captured group by the result of a closure call on that text. |
|
static String |
replaceFirst(String self,
Pattern pattern,
Closure closure)
Replaces the first occurrence of a captured group by the result of a closure call on that text. |
|
static String |
replaceFirst(String self,
Pattern pattern,
String replacement)
Replaces the first substring of a String that matches the given compiled regular expression with the given replacement. |
|
static String |
replaceFirst(String self,
String regex,
Closure closure)
Replaces the first occurrence of a captured group by the result of a closure call on that text. |
|
static List<MetaMethod> |
respondsTo(Object self,
String name)
Returns an object satisfying Groovy truth if the implementing MetaClass responds to a method with the given name regardless of the arguments. |
|
static List<MetaMethod> |
respondsTo(Object self,
String name,
Object[] argTypes)
Returns an object satisfying Groovy truth if the implementing MetaClass responds to a method with the given name and arguments types. |
|
static boolean |
retainAll(Collection self,
Closure condition)
Modifies this collection so that it retains only its elements that are matched according to the specified closure condition. |
|
static boolean |
retainAll(Collection self,
Object[] items)
Modifies this collection so that it retains only its elements that are contained in the specified array. |
|
static CharSequence |
reverse(CharSequence self)
Creates a new CharSequence which is the reverse (backwards) of this string |
|
static
|
reverse(Iterator<T> self)
Reverses the iterator. |
|
static
|
reverse(List<T> self)
Creates a new List with the identical contents to this list but in reverse order. |
|
static
|
reverse(List<T> self,
boolean mutate)
Reverses the elements in a list. |
|
static String |
reverse(String self)
Creates a new string which is the reverse (backwards) of this string |
|
static
|
reverse(T[] self)
Creates a new array containing items which are the same as this array but in reverse order. |
|
static
|
reverse(T[] self,
boolean mutate)
Reverse the items in an array. |
|
static
|
reverseEach(List<T> self,
Closure closure)
Iterate over each element of the list in the reverse order. |
|
static
|
reverseEach(Map<K,V> self,
Closure closure)
Allows a Map to be iterated through in reverse order using a closure. |
|
static
|
reverseEach(T[] self,
Closure closure)
Iterate over each element of the array in the reverse order. |
|
static Number |
rightShift(Number self,
Number operand)
Implementation of the right shift operator for integral types. |
|
static Number |
rightShiftUnsigned(Number self,
Number operand)
Implementation of the right shift (unsigned) operator for integral types. |
|
static long |
round(Double number)
Round the value |
|
static double |
round(Double number,
int precision)
Round the value |
|
static int |
round(Float number)
Round the value |
|
static float |
round(Float number,
int precision)
Round the value |
|
static TimerTask |
runAfter(Timer timer,
int delay,
Closure closure)
Allows a simple syntax for using timers. |
|
static void |
setBytes(File file,
byte[] bytes)
Write the bytes from the byte array to the File. |
|
static void |
setBytes(OutputStream os,
byte[] bytes)
Write the byte[] to the output stream. |
|
static void |
setIndex(Matcher matcher,
int idx)
Set the position of the given Matcher to the given index. |
|
static void |
setMetaClass(Class self,
MetaClass metaClass)
Sets the metaclass for a given class. |
|
static void |
setMetaClass(Object self,
MetaClass metaClass)
Set the metaclass for an object |
|
static void |
setText(File file,
String text)
Synonym for write(text) allowing file.text = 'foo'. |
|
static void |
setText(File file,
String text,
String charset)
Synonym for write(text, charset) allowing: myFile.setText('some text', charset) or with some help from ExpandoMetaClass , you could do something like:
myFile.metaClass.setText = { String s -> delegate.setText(s, 'UTF-8') }
myfile.text = 'some text'
|
|
static int |
size(boolean[] array)
Allows arrays to behave similar to collections. |
|
static int |
size(byte[] array)
Allows arrays to behave similar to collections. |
|
static int |
size(char[] array)
Allows arrays to behave similar to collections. |
|
static int |
size(CharSequence text)
Provide the standard Groovy size() method for CharSequence . |
|
static int |
size(double[] array)
Allows arrays to behave similar to collections. |
|
static long |
size(File self)
Provide the standard Groovy size() method for File . |
|
static int |
size(float[] array)
Allows arrays to behave similar to collections. |
|
static int |
size(int[] array)
Allows arrays to behave similar to collections. |
|
static int |
size(Iterator self)
Provide the standard Groovy size() method for Iterator . |
|
static int |
size(long[] array)
Allows arrays to behave similar to collections. |
|
static long |
size(Matcher self)
Provide the standard Groovy size() method for Matcher . |
|
static int |
size(Object[] self)
Provide the standard Groovy size() method for an array. |
|
static int |
size(short[] array)
Allows arrays to behave similar to collections. |
|
static int |
size(String text)
Provide the standard Groovy size() method for String . |
|
static int |
size(StringBuffer buffer)
Provide the standard Groovy size() method for StringBuffer . |
|
static
|
sort(Collection<T> self)
Sorts the Collection. |
|
static
|
sort(Collection<T> self,
boolean mutate)
Sorts the Collection. |
|
static
|
sort(Collection<T> self,
boolean mutate,
Closure closure)
Sorts this Collection using the given Closure to determine the correct ordering. |
|
static
|
sort(Collection<T> self,
boolean mutate,
Comparator<T> comparator)
Sorts the Collection using the given Comparator. |
|
static
|
sort(Collection<T> self,
Closure closure)
Sorts this Collection using the given Closure to determine the correct ordering. |
|
static
|
sort(Collection<T> self,
Comparator<T> comparator)
Sorts the Collection using the given Comparator. |
|
static
|
sort(Iterator<T> self)
Sorts the given iterator items into a sorted iterator. |
|
static
|
sort(Iterator<T> self,
Closure closure)
Sorts the given iterator items into a sorted iterator using the Closure to determine the correct ordering. |
|
static
|
sort(Iterator<T> self,
Comparator<T> comparator)
Sorts the given iterator items into a sorted iterator using the comparator. |
|
static
|
sort(Map<K,V> self)
Sorts the elements from the given map into a new ordered Map using the natural ordering of the keys to determine the ordering. |
|
static
|
sort(Map<K,V> self,
Closure closure)
Sorts the elements from the given map into a new ordered map using the closure as a comparator to determine the ordering. |
|
static
|
sort(Map<K,V> self,
Comparator<K> comparator)
Sorts the elements from the given map into a new ordered Map using the specified key comparator to determine the ordering. |
|
static
|
sort(SortedMap<K,V> self)
Avoids doing unnecessary work when sorting an already sorted map (i.e. an identity function for an already sorted map). |
|
static
|
sort(SortedSet<T> self)
Avoids doing unnecessary work when sorting an already sorted set (i.e. an identity function for an already sorted set). |
|
static
|
sort(T[] self)
Modifies this array so that its elements are in sorted order. |
|
static
|
sort(T[] self,
boolean mutate)
Sorts the given array into sorted order. |
|
static
|
sort(T[] self,
boolean mutate,
Closure closure)
Modifies this array so that its elements are in sorted order using the Closure to determine the correct ordering. |
|
static
|
sort(T[] self,
boolean mutate,
Comparator<T> comparator)
Modifies this array so that its elements are in sorted order as determined by the given comparator. |
|
static
|
sort(T[] self,
Closure closure)
Sorts the elements from this array into a newly created array using the Closure to determine the correct ordering. |
|
static
|
sort(T[] self,
Comparator<T> comparator)
Sorts the given array into sorted order using the given comparator. |
|
static CharSequence[] |
split(CharSequence self)
Convenience method to split a CharSequence (with whitespace as delimiter). |
|
static
|
split(Collection<T> self,
Closure closure)
Splits all items into two collections based on the closure condition. |
|
static String[] |
split(GString self)
Convenience method to split a GString (with whitespace as delimiter). |
|
static Collection |
split(Object self,
Closure closure)
Splits all items into two lists based on the closure condition. |
|
static String[] |
split(String self)
Convenience method to split a string (with whitespace as delimiter) Like tokenize, but returns an Array of Strings instead of a List |
|
static
|
splitEachLine(CharSequence self,
CharSequence regex,
Closure<T> closure)
Iterates through the given CharSequence line by line, splitting each line using the given separator. |
|
static
|
splitEachLine(CharSequence self,
Pattern pattern,
Closure<T> closure)
Iterates through the given CharSequence line by line, splitting each line using the given separator Pattern. |
|
static
|
splitEachLine(File self,
Pattern pattern,
Closure<T> closure)
Iterates through this file line by line, splitting each line using the given separator Pattern. |
|
static
|
splitEachLine(File self,
Pattern pattern,
String charset,
Closure<T> closure)
Iterates through this file line by line, splitting each line using the given regex separator Pattern. |
|
static
|
splitEachLine(File self,
String regex,
Closure<T> closure)
Iterates through this file line by line, splitting each line using the given regex separator. |
|
static
|
splitEachLine(File self,
String regex,
String charset,
Closure<T> closure)
Iterates through this file line by line, splitting each line using the given regex separator. |
|
static
|
splitEachLine(InputStream stream,
Pattern pattern,
Closure<T> closure)
Iterates through the given InputStream line by line, splitting each line using the given separator Pattern. |
|
static
|
splitEachLine(InputStream stream,
Pattern pattern,
String charset,
Closure<T> closure)
Iterates through the given InputStream line by line using the specified encoding, splitting each line using the given separator Pattern. |
|
static
|
splitEachLine(InputStream stream,
String regex,
Closure<T> closure)
Iterates through the given InputStream line by line, splitting each line using the given separator. |
|
static
|
splitEachLine(InputStream stream,
String regex,
String charset,
Closure<T> closure)
Iterates through the given InputStream line by line using the specified encoding, splitting each line using the given separator. |
|
static
|
splitEachLine(Reader self,
Pattern pattern,
Closure<T> closure)
Iterates through the given reader line by line, splitting each line using the given regex separator Pattern. |
|
static
|
splitEachLine(Reader self,
String regex,
Closure<T> closure)
Iterates through the given reader line by line, splitting each line using the given regex separator. |
|
static
|
splitEachLine(String self,
Pattern pattern,
Closure<T> closure)
Iterates through the given String line by line, splitting each line using the given separator Pattern. |
|
static
|
splitEachLine(String self,
String regex,
Closure<T> closure)
Iterates through the given String line by line, splitting each line using the given separator. |
|
static
|
splitEachLine(URL self,
Pattern pattern,
Closure<T> closure)
Iterates through the input stream associated with this URL line by line, splitting each line using the given regex separator Pattern. |
|
static
|
splitEachLine(URL self,
Pattern pattern,
String charset,
Closure<T> closure)
Iterates through the input stream associated with this URL line by line, splitting each line using the given regex separator Pattern. |
|
static
|
splitEachLine(URL self,
String regex,
Closure<T> closure)
Iterates through the input stream associated with this URL line by line, splitting each line using the given regex separator. |
|
static
|
splitEachLine(URL self,
String regex,
String charset,
Closure<T> closure)
Iterates through the input stream associated with this URL line by line, splitting each line using the given regex separator. |
|
static SpreadMap |
spread(Map self)
Synonym for toSpreadMap(java.util.Map) . |
|
static String |
sprintf(Object self,
String format,
Object arg)
Returns a formatted string using the specified format string and arguments. |
|
static String |
sprintf(Object self,
String format,
Object[] values)
Sprintf to a string (Only works with JDK1.5 or later). |
|
static void |
step(Number self,
Number to,
Number stepNumber,
Closure closure)
Iterates from this number up to the given number using a step increment. |
|
static CharSequence |
stripIndent(CharSequence self)
Strip leading spaces from every line in a CharSequence. |
|
static CharSequence |
stripIndent(CharSequence self,
int numChars)
Strip numChar leading characters from every line in a CharSequence. |
|
static String |
stripIndent(String self)
Strip leading spaces from every line in a String. |
|
static String |
stripIndent(String self,
int numChars)
Strip numChar leading characters from every line in a String. |
|
static CharSequence |
stripMargin(CharSequence self)
Strip leading whitespace/control characters followed by '|' from every line in a CharSequence. |
|
static CharSequence |
stripMargin(CharSequence self,
char marginChar)
Strip leading whitespace/control characters followed by marginChar from every line in a String. |
|
static String |
stripMargin(CharSequence self,
CharSequence marginChar)
Strip leading whitespace/control characters followed by marginChar from every line in a CharSequence. |
|
static String |
stripMargin(String self)
Strip leading whitespace/control characters followed by '|' from every line in a String. |
|
static String |
stripMargin(String self,
char marginChar)
Strip leading whitespace/control characters followed by marginChar from every line in a String. |
|
static String |
stripMargin(String self,
String marginChar)
Strip leading whitespace/control characters followed by marginChar from every line in a String. |
|
static
|
subMap(Map<K,V> map,
Collection<K> keys)
Creates a sub-Map containing the given keys. |
|
static
|
subsequences(List<T> self)
Finds all non-null subsequences of a list. |
|
static Object |
sum(Collection self)
Sums the items in a collection. |
|
static Object |
sum(Collection self,
Closure closure)
Sums the result of apply a closure to each item of a collection. |
|
static Object |
sum(Collection self,
Object initialValue)
Sums the items in a collection, adding the result to some initial value. |
|
static Object |
sum(Collection self,
Object initialValue,
Closure closure)
Sums the result of applying a closure to each item of a collection to some initial value. |
|
static Object |
sum(Iterator<Object> self)
Sums the items from an Iterator. |
|
static Object |
sum(Iterator<Object> self,
Closure closure)
Sums the result of apply a closure to each item returned from an iterator. |
|
static Object |
sum(Iterator<Object> self,
Object initialValue)
Sums the items from an Iterator, adding the result to some initial value. |
|
static Object |
sum(Iterator<Object> self,
Object initialValue,
Closure closure)
Sums the result of applying a closure to each item of an Iterator to some initial value. |
|
static Object |
sum(Object[] self)
Sums the items in an array. |
|
static Object |
sum(Object[] self,
Closure closure)
Sums the result of apply a closure to each item of an array. |
|
static Object |
sum(Object[] self,
Object initialValue)
Sums the items in an array, adding the result to some initial value. |
|
static Object |
sum(Object[] self,
Object initialValue,
Closure closure)
Sums the result of applying a closure to each item of an array to some initial value. |
|
static
|
tail(List<T> self)
Returns the items from the List excluding the first item. |
|
static
|
tail(T[] self)
Returns the items from the Object array excluding the first item. |
|
static CharSequence |
take(CharSequence self,
int num)
Returns the first num elements from this CharSequence. |
|
static
|
take(Iterable<T> self,
int num)
Returns the first num elements from the head of this Iterable. |
|
static
|
take(Iterator<T> self,
int num)
Returns an iterator of up to the first num elements from this iterator. |
|
static
|
take(List<T> self,
int num)
Returns the first num elements from the head of this list. |
|
static
|
take(Map<K,V> self,
int num)
Returns a new map containing the first num elements from the head of this map. |
|
static
|
take(T[] self,
int num)
Returns the first num elements from the head of this array. |
|
static CharSequence |
takeWhile(CharSequence self,
Closure closure)
Returns the longest prefix of this CharSequence where each element passed to the given closure evalutes to true. |
|
static
|
takeWhile(Iterable<T> self,
Closure condition)
Returns a List containing the longest prefix of the elements from this Iterable where each element passed to the given closure evaluates to true. |
|
static
|
takeWhile(Iterator<T> self,
Closure condition)
Returns the longest prefix of elements in this iterator where each element passed to the given condition closure evaluates to true. |
|
static
|
takeWhile(List<T> self,
Closure condition)
Returns the longest prefix of this list where each element passed to the given closure condition evaluates to true. |
|
static
|
takeWhile(Map<K,V> self,
Closure<?> condition)
Returns the longest prefix of this Map where each entry (or key/value pair) when passed to the given closure evaluates to true. |
|
static
|
takeWhile(T[] self,
Closure condition)
Returns the longest prefix of this array where each element passed to the given closure evaluates to true. |
|
static void |
times(Number self,
Closure closure)
Executes the closure this many times, starting from zero. |
|
static String |
toArrayString(Object[] self)
Returns the string representation of the given array. |
|
static BigDecimal |
toBigDecimal(CharSequence self)
Parse a CharSequence into a BigDecimal |
|
static BigDecimal |
toBigDecimal(Number self)
Transform a Number into a BigDecimal |
|
static BigDecimal |
toBigDecimal(String self)
Parse a String into a BigDecimal |
|
static BigInteger |
toBigInteger(CharSequence self)
Parse a CharSequence into a BigInteger |
|
static BigInteger |
toBigInteger(Number self)
Transform this Number into a BigInteger. |
|
static BigInteger |
toBigInteger(String self)
Parse a String into a BigInteger |
|
static Boolean |
toBoolean(Boolean self)
Identity conversion which returns Boolean.TRUE for a true Boolean and Boolean.FALSE for a false Boolean. |
|
static Boolean |
toBoolean(String self)
Converts the given string into a Boolean object. |
|
static Character |
toCharacter(String self)
Converts the given string into a Character object using the first character in the string. |
|
static Double |
toDouble(CharSequence self)
Parse a CharSequence into a Double |
|
static Double |
toDouble(Number self)
Transform a Number into a Double |
|
static Double |
toDouble(String self)
Parse a String into a Double |
|
static Float |
toFloat(CharSequence self)
Parse a CharSequence into a Float |
|
static Float |
toFloat(Number self)
Transform a Number into a Float |
|
static Float |
toFloat(String self)
Parse a String into a Float |
|
static Integer |
toInteger(CharSequence self)
Parse a CharSequence into an Integer |
|
static Integer |
toInteger(Number self)
Transform a Number into an Integer |
|
static Integer |
toInteger(String self)
Parse a String into an Integer |
|
static List<CharSequence> |
tokenize(CharSequence self)
Tokenize a CharSequence (with a whitespace as the delimiter). |
|
static List<CharSequence> |
tokenize(CharSequence self,
Character token)
Tokenize a CharSequence based on the given character delimiter. |
|
static List<CharSequence> |
tokenize(CharSequence self,
CharSequence token)
Tokenize a CharSequence based on the given CharSequence delimiter. |
|
static List<String> |
tokenize(String self)
Tokenize a String (with a whitespace as the delimiter). |
|
static List<String> |
tokenize(String self,
Character token)
Tokenize a String based on the given character delimiter. |
|
static List<String> |
tokenize(String self,
String token)
Tokenize a String based on the given string delimiter. |
|
static List<Boolean> |
toList(boolean[] array)
Converts this array to a List of the same size, with each element added to the list. |
|
static List<Byte> |
toList(byte[] array)
Converts this array to a List of the same size, with each element added to the list. |
|
static List<Character> |
toList(char[] array)
Converts this array to a List of the same size, with each element added to the list. |
|
static List<CharSequence> |
toList(CharSequence self)
Converts the given CharSequence into a List of CharSequence of one character. |
|
static
|
toList(Collection<T> self)
Convert a Collection to a List. |
|
static List<Double> |
toList(double[] array)
Converts this array to a List of the same size, with each element added to the list. |
|
static
|
toList(Enumeration<T> self)
Convert an enumeration to a List. |
|
static List<Float> |
toList(float[] array)
Converts this array to a List of the same size, with each element added to the list. |
|
static List<Integer> |
toList(int[] array)
Converts this array to a List of the same size, with each element added to the list. |
|
static
|
toList(Iterable<T> self)
Convert an Iterable to a List. |
|
static
|
toList(Iterator<T> self)
Convert an iterator to a List. |
|
static List<Long> |
toList(long[] array)
Converts this array to a List of the same size, with each element added to the list. |
|
static List<Short> |
toList(short[] array)
Converts this array to a List of the same size, with each element added to the list. |
|
static List<String> |
toList(String self)
Converts the given String into a List of strings of one character. |
|
static
|
toList(T[] array)
Allows conversion of arrays into a mutable List. |
|
static String |
toListString(Collection self)
Returns the string representation of the given list. |
|
static String |
toListString(Collection self,
int maxSize)
Returns the string representation of the given list. |
|
static Long |
toLong(CharSequence self)
Parse a CharSequence into a Long |
|
static Long |
toLong(Number self)
Transform a Number into a Long |
|
static Long |
toLong(String self)
Parse a String into a Long |
|
static char |
toLowerCase(Character self)
Converts the character to lowercase. |
|
static String |
toMapString(Map self)
Returns the string representation of this map. |
|
static String |
toMapString(Map self,
int maxSize)
Returns the string representation of this map. |
|
static Set<Boolean> |
toSet(boolean[] array)
Converts this array to a Set, with each unique element added to the set. |
|
static Set<Byte> |
toSet(byte[] array)
Converts this array to a Set, with each unique element added to the set. |
|
static Set<Character> |
toSet(char[] array)
Converts this array to a Set, with each unique element added to the set. |
|
static Set<CharSequence> |
toSet(CharSequence self)
Converts the given CharSequence into a Set of unique CharSequence of one character. |
|
static
|
toSet(Collection<T> self)
Convert a Collection to a Set. |
|
static Set<Double> |
toSet(double[] array)
Converts this array to a Set, with each unique element added to the set. |
|
static
|
toSet(Enumeration<T> self)
Convert an enumeration to a Set. |
|
static Set<Float> |
toSet(float[] array)
Converts this array to a Set, with each unique element added to the set. |
|
static Set<Integer> |
toSet(int[] array)
Converts this array to a Set, with each unique element added to the set. |
|
static
|
toSet(Iterator<T> self)
Convert an iterator to a Set. |
|
static Set<Long> |
toSet(long[] array)
Converts this array to a Set, with each unique element added to the set. |
|
static Set<Short> |
toSet(short[] array)
Converts this array to a Set, with each unique element added to the set. |
|
static Set<String> |
toSet(String self)
Converts the given String into a Set of unique strings of one character. |
|
static Short |
toShort(CharSequence self)
Parse a CharSequence into a Short |
|
static Short |
toShort(String self)
Parse a String into a Short |
|
static SpreadMap |
toSpreadMap(List self)
Creates a spreadable map from this list. |
|
static SpreadMap |
toSpreadMap(Map self)
Returns a new SpreadMap from this map. |
|
static SpreadMap |
toSpreadMap(Object[] self)
Creates a spreadable map from this array. |
|
static String |
toString(AbstractCollection self)
Returns the string representation of the given collection. |
|
static String |
toString(AbstractMap self)
Returns the string representation of the given map. |
|
static String |
toString(boolean[] self)
Returns the string representation of the given array. |
|
static String |
toString(byte[] self)
Returns the string representation of the given array. |
|
static String |
toString(char[] self)
Returns the string representation of the given array. |
|
static String |
toString(double[] self)
Returns the string representation of the given array. |
|
static String |
toString(float[] self)
Returns the string representation of the given array. |
|
static String |
toString(int[] self)
Returns the string representation of the given array. |
|
static String |
toString(long[] self)
Returns the string representation of the given array. |
|
static String |
toString(Object value)
Create a String representation of this object. |
|
static String |
toString(Object[] self)
Returns the string representation of this array's contents. |
|
static String |
toString(short[] self)
Returns the string representation of the given array. |
|
static char |
toUpperCase(Character self)
Converts the character to uppercase. |
|
static URI |
toURI(CharSequence self)
Transforms a CharSequence representing a URI into a URI object. |
|
static URI |
toURI(String self)
Transforms a String representing a URI into a URI object. |
|
static URL |
toURL(CharSequence self)
Transforms a CharSequence representing a URL into a URL object. |
|
static URL |
toURL(String self)
Transforms a String representing a URL into a URL object. |
|
static CharSequence |
tr(CharSequence self,
CharSequence sourceSet,
CharSequence replacementSet)
Translates a string by replacing characters from the sourceSet with characters from replacementSet. |
|
static String |
tr(String self,
String sourceSet,
String replacementSet)
Translates a string by replacing characters from the sourceSet with characters from replacementSet. |
|
static void |
transformChar(Reader self,
Writer writer,
Closure closure)
Transforms each character from this reader by passing it to the given closure. |
|
static void |
transformLine(Reader reader,
Writer writer,
Closure closure)
Transforms the lines from a reader with a Closure and write them to a writer. |
|
static List |
transpose(List self)
Adds GroovyCollections#transpose(List) as a method on lists. |
|
static void |
traverse(File self,
Closure closure)
Invokes the closure for each descendant file in this directory tree. |
|
static void |
traverse(File self,
Map<String,Object> options)
Invokes the closure specified with key 'visit' in the options Map for each descendant file in this directory tree. |
|
static void |
traverse(File self,
Map<String,Object> options,
Closure closure)
Invokes closure for each descendant file in this directory tree. |
|
static double |
trunc(Double number)
Truncate the value |
|
static double |
trunc(Double number,
int precision)
Truncate the value |
|
static float |
trunc(Float number)
Truncate the value |
|
static float |
trunc(Float number,
int precision)
Truncate the value |
|
static Number |
unaryMinus(Number left)
Negates the number. |
|
static CharSequence |
unexpand(CharSequence self)
Replaces sequences of whitespaces with tabs using tabStops of size 8. |
|
static CharSequence |
unexpand(CharSequence self,
int tabStop)
Replaces sequences of whitespaces with tabs. |
|
static String |
unexpand(String self)
Replaces sequences of whitespaces with tabs using tabStops of size 8. |
|
static String |
unexpand(String self,
int tabStop)
Replaces sequences of whitespaces with tabs. |
|
static CharSequence |
unexpandLine(CharSequence self,
int tabStop)
Replaces sequences of whitespaces with tabs within a line. |
|
static String |
unexpandLine(String self,
int tabStop)
Replaces sequences of whitespaces with tabs within a line. |
|
static
|
unique(Collection<T> self)
Modifies this collection to remove all duplicated items, using the default comparator. |
|
static
|
unique(Collection<T> self,
boolean mutate)
Remove all duplicates from a given Collection using the default comparator. |
|
static
|
unique(Collection<T> self,
boolean mutate,
Closure closure)
A convenience method for making a collection unique using a Closure to determine duplicate (equal) items. |
|
static
|
unique(Collection<T> self,
boolean mutate,
Comparator<T> comparator)
Remove all duplicates from a given Collection. |
|
static
|
unique(Collection<T> self,
Closure closure)
A convenience method for making a collection unique using a Closure to determine duplicate (equal) items. |
|
static
|
unique(Collection<T> self,
Comparator<T> comparator)
Remove all duplicates from a given Collection. |
|
static
|
unique(Iterator<T> self)
Returns an iterator equivalent to this iterator all duplicated items removed by using the default comparator. |
|
static
|
unique(Iterator<T> self,
Closure closure)
Returns an iterator equivalent to this iterator but with all duplicated items removed by using a Closure to determine duplicate (equal) items. |
|
static
|
unique(Iterator<T> self,
Comparator<T> comparator)
Returns an iterator equivalent to this iterator with all duplicated items removed by using the supplied comparator. |
|
static void |
upto(BigDecimal self,
Number to,
Closure closure)
Iterates from this number up to the given number, inclusive, incrementing by one each time. |
|
static void |
upto(BigInteger self,
Number to,
Closure closure)
Iterates from this number up to the given number, inclusive, incrementing by one each time. |
|
static void |
upto(double self,
Number to,
Closure closure)
Iterates from this number up to the given number, inclusive, incrementing by one each time. |
|
static void |
upto(Double self,
Number to,
Closure closure)
Iterates from this number up to the given number, inclusive, incrementing by one each time. |
|
static void |
upto(float self,
Number to,
Closure closure)
Iterates from this number up to the given number, inclusive, incrementing by one each time. |
|
static void |
upto(Float self,
Number to,
Closure closure)
Iterates from this number up to the given number, inclusive, incrementing by one each time. |
|
static void |
upto(long self,
Number to,
Closure closure)
Iterates from this number up to the given number, inclusive, incrementing by one each time. |
|
static void |
upto(Long self,
Number to,
Closure closure)
Iterates from this number up to the given number, inclusive, incrementing by one each time. |
|
static void |
upto(Number self,
Number to,
Closure closure)
Iterates from this number up to the given number, inclusive, incrementing by one each time. |
|
static
|
use(Object self,
Class categoryClass,
Closure<T> closure)
Scoped use method |
|
static
|
use(Object self,
List<Class> categoryClassList,
Closure<T> closure)
Scoped use method with list of categories. |
|
static Object |
use(Object self,
Object[] array)
Allows you to use a list of categories, specifying the list as varargs. |
|
static
|
with(Object self,
Closure<T> closure)
Allows the closure to be called for the object reference self. |
|
static
|
withDataInputStream(File file,
Closure<T> closure)
Create a new DataInputStream for this file and passes it into the closure. |
|
static
|
withDataOutputStream(File file,
Closure<T> closure)
Create a new DataOutputStream for this file and passes it into the closure. |
|
static
|
withDefault(List<T> self,
Closure init)
An alias for withLazyDefault which decorates a list allowing
it to grow when called with index values outside the normal list bounds. |
|
static
|
withDefault(Map<K,V> self,
Closure init)
Wraps a map using the decorator pattern with a wrapper that intercepts all calls to get(key) . |
|
static
|
withEagerDefault(List<T> self,
Closure init)
Decorates a list allowing it to grow when called with a non-existent index value. |
|
static Object |
withInputStream(File file,
Closure closure)
Create a new InputStream for this file and passes it into the closure. |
|
static
|
withInputStream(URL url,
Closure<T> closure)
Creates a new InputStream for this URL and passes it into the closure. |
|
static
|
withLazyDefault(List<T> self,
Closure init)
Decorates a list allowing it to grow when called with a non-existent index value. |
|
static
|
withObjectInputStream(File file,
ClassLoader classLoader,
Closure<T> closure)
Create a new ObjectInputStream for this file associated with the given class loader and pass it to the closure. |
|
static
|
withObjectInputStream(File file,
Closure<T> closure)
Create a new ObjectInputStream for this file and pass it to the closure. |
|
static
|
withObjectInputStream(InputStream inputStream,
ClassLoader classLoader,
Closure<T> closure)
Create a new ObjectInputStream for this file and pass it to the closure. |
|
static
|
withObjectInputStream(InputStream inputStream,
Closure<T> closure)
Create a new ObjectInputStream for this file and pass it to the closure. |
|
static
|
withObjectOutputStream(File file,
Closure<T> closure)
Create a new ObjectOutputStream for this file and then pass it to the closure. |
|
static
|
withObjectOutputStream(OutputStream outputStream,
Closure<T> closure)
Create a new ObjectOutputStream for this output stream and then pass it to the closure. |
|
static
|
withObjectStreams(Socket socket,
Closure<T> closure)
Creates an InputObjectStream and an OutputObjectStream from a Socket, and passes them to the closure. |
|
static Object |
withOutputStream(File file,
Closure closure)
Creates a new OutputStream for this file and passes it into the closure. |
|
static
|
withPrintWriter(File file,
Closure<T> closure)
Create a new PrintWriter for this file which is then passed it into the given closure. |
|
static
|
withPrintWriter(File file,
String charset,
Closure<T> closure)
Create a new PrintWriter with a specified charset for this file. |
|
static
|
withPrintWriter(Writer writer,
Closure<T> closure)
Create a new PrintWriter with a specified charset for this file. |
|
static
|
withReader(File file,
Closure<T> closure)
Create a new BufferedReader for this file and then passes it into the closure, ensuring the reader is closed after the closure returns. |
|
static
|
withReader(File file,
String charset,
Closure<T> closure)
Create a new BufferedReader for this file using the specified charset and then passes it into the closure, ensuring the reader is closed after the closure returns. |
|
static
|
withReader(InputStream in,
Closure<T> closure)
Helper method to create a new Reader for a stream and then passes it into the closure. |
|
static
|
withReader(InputStream in,
String charset,
Closure<T> closure)
Helper method to create a new Reader for a stream and then passes it into the closure. |
|
static
|
withReader(Reader reader,
Closure<T> closure)
Allows this reader to be used within the closure, ensuring that it is closed before this method returns. |
|
static
|
withReader(URL url,
Closure<T> closure)
Helper method to create a new BufferedReader for a URL and then passes it to the closure. |
|
static
|
withReader(URL url,
String charset,
Closure<T> closure)
Helper method to create a new Reader for a URL and then passes it to the closure. |
|
static
|
withStream(InputStream stream,
Closure<T> closure)
Allows this input stream to be used within the closure, ensuring that it is flushed and closed before this method returns. |
|
static
|
withStream(OutputStream os,
Closure<T> closure)
Passes this OutputStream to the closure, ensuring that the stream is closed after the closure returns, regardless of errors. |
|
static
|
withStreams(Socket socket,
Closure<T> closure)
Passes the Socket's InputStream and OutputStream to the closure. |
|
static
|
withWriter(File file,
Closure<T> closure)
Creates a new BufferedWriter for this file, passes it to the closure, and ensures the stream is flushed and closed after the closure returns. |
|
static
|
withWriter(File file,
String charset,
Closure<T> closure)
Creates a new BufferedWriter for this file, passes it to the closure, and ensures the stream is flushed and closed after the closure returns. |
|
static
|
withWriter(OutputStream stream,
Closure<T> closure)
Creates a writer from this stream, passing it to the given closure. |
|
static
|
withWriter(OutputStream stream,
String charset,
Closure<T> closure)
Creates a writer from this stream, passing it to the given closure. |
|
static
|
withWriter(Writer writer,
Closure<T> closure)
Allows this writer to be used within the closure, ensuring that it is flushed and closed before this method returns. |
|
static
|
withWriterAppend(File file,
Closure<T> closure)
Create a new BufferedWriter for this file in append mode. |
|
static
|
withWriterAppend(File file,
String charset,
Closure<T> closure)
Create a new BufferedWriter which will append to this file. |
|
static void |
write(File file,
String text)
Write the text to the File. |
|
static void |
write(File file,
String text,
String charset)
Write the text to the File, using the specified encoding. |
|
static void |
write(Writer self,
Writable writable)
A helper method so that dynamic dispatch of the writer.write(object) method will always use the more efficient Writable.writeTo(writer) mechanism if the object implements the Writable interface. |
|
static void |
writeLine(BufferedWriter writer,
String line)
Write the text and append a newline (using the platform's line-ending). |
|
static BitSet |
xor(BitSet left,
BitSet right)
Bitwise XOR together two BitSets. |
|
static Boolean |
xor(Boolean left,
Boolean right)
Exclusive disjunction of two boolean operators |
|
static Number |
xor(Number left,
Number right)
Bitwise XOR together two Numbers. |
Methods inherited from class org.codehaus.groovy.runtime.DefaultGroovyMethodsSupport |
---|
cloneSimilarCollection, cloneSimilarMap, closeQuietly, closeWithWarning, createSimilarArray, createSimilarCollection, createSimilarCollection, createSimilarList, createSimilarMap, createSimilarOrDefaultCollection, createSimilarSet, normaliseIndex, sameType, subListBorders, subListBorders |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
public static final Class[] additionals
Constructor Detail |
---|
public DefaultGroovyMethods()
Method Detail |
---|
public static boolean is(Object self, Object other)
def same = this.is(that)
self
- an objectother
- an object to compare identity with
public static <T> T identity(Object self, Closure<T> closure)
self
- the object to have a closure act uponclosure
- the closure to call on the object
public static <T> T with(Object self, Closure<T> closure)
def b = new StringBuilder().with { append('foo') append('bar') return it } assert b.toString() == 'foobar'This is commonly used to simplify object creation, such as this example:
def p = new Person().with { firstName = 'John' lastName = 'Doe' return it }
self
- the object to have a closure act uponclosure
- the closure to call on the object
public static Object getAt(Object self, String property)
bean[somePropertyNameExpression]
. The normal property notation
of groovy is neater and more concise but only works with compile-time known
property names.
self
- the object to act uponproperty
- the property name of interest
public static void putAt(Object self, String property, Object newValue)
bean[somePropertyNameExpression] = foo
. The normal property notation
of groovy is neater and more concise but only works with property names which
are known at compile time.
self
- the object to act uponproperty
- the name of the property to setnewValue
- the value to setpublic static String dump(Object self)
self
- an object
public static List<PropertyValue> getMetaPropertyValues(Object self)
MetaProperty
objects for 'self' and wraps it
in a list of PropertyValue
objects that additionally provide
the value for each property of 'self'.
self
- the receiver object
PropertyValue
objectsExpando.getMetaPropertyValues()
public static Map getProperties(Object self)
getMetaPropertyValues(java.lang.Object)
(self)
and provides the data in form of simple key/value pairs, i.e.&nsbp;without
type() information.
self
- the receiver object
public static <T> T use(Object self, Class categoryClass, Closure<T> closure)
self
- any ObjectcategoryClass
- a category class to useclosure
- the closure to invoke with the category in place
public static void mixin(MetaClass self, List<Class> categoryClasses)
self
- any ClasscategoryClasses
- a category classes to usepublic static void mixin(Class self, List<Class> categoryClasses)
self
- any ClasscategoryClasses
- a category classes to usepublic static void mixin(Class self, Class categoryClass)
self
- any ClasscategoryClass
- a category class to usepublic static void mixin(Class self, Class[] categoryClass)
self
- any ClasscategoryClass
- a category class to usepublic static void mixin(MetaClass self, Class categoryClass)
self
- any ClasscategoryClass
- a category class to usepublic static void mixin(MetaClass self, Class[] categoryClass)
self
- any ClasscategoryClass
- a category class to usepublic static <T> T use(Object self, List<Class> categoryClassList, Closure<T> closure)
self
- any ObjectcategoryClassList
- a list of category classesclosure
- the closure to invoke with the categories in place
public static void addShutdownHook(Object self, Closure closure)
self
- the object the method is called on (ignored)closure
- the shutdown hook actionpublic static Object use(Object self, Object[] array)
use(CategoryClass1, CategoryClass2) { ... }
This method saves having to wrap the the category
classes in a list.
self
- any Objectarray
- a list of category classes and a Closure
public static void print(Object self, Object value)
self
- any Objectvalue
- the value to printpublic static void print(PrintWriter self, Object value)
self
- a PrintWritervalue
- the value to printpublic static void print(PrintStream self, Object value)
self
- a PrintStreamvalue
- the value to printpublic static void print(Closure self, Object value)
self
- a generated closurevalue
- the value to printpublic static void println(Object self)
self
- any Objectpublic static void println(Closure self)
self
- a closurepublic static void println(Object self, Object value)
self
- any Objectvalue
- the value to printpublic static void println(PrintWriter self, Object value)
self
- a PrintWritervalue
- the value to printpublic static void println(PrintStream self, Object value)
self
- any Objectvalue
- the value to printpublic static void println(Closure self, Object value)
self
- a closurevalue
- the value to printpublic static void printf(Object self, String format, Object[] values)
self
- any Objectformat
- a format stringvalues
- values referenced by the format specifiers in the format string.public static String sprintf(Object self, String format, Object[] values)
self
- any Objectformat
- a format stringvalues
- values referenced by the format specifiers in the format string.
public static void printf(Object self, String format, Object arg)
printf ( "Hello, %s!\n" , [ "world" ] as String[] ) printf ( "Hello, %s!\n" , [ "Groovy" ]) printf ( "%d + %d = %d\n" , [ 1 , 2 , 1+2 ] as Integer[] ) printf ( "%d + %d = %d\n" , [ 3 , 3 , 3+3 ]) ( 1..5 ).each { printf ( "-- %d\n" , [ it ] as Integer[] ) } ( 1..5 ).each { printf ( "-- %d\n" , [ it ] as int[] ) } ( 0x41..0x45 ).each { printf ( "-- %c\n" , [ it ] as char[] ) } ( 07..011 ).each { printf ( "-- %d\n" , [ it ] as byte[] ) } ( 7..11 ).each { printf ( "-- %d\n" , [ it ] as short[] ) } ( 7..11 ).each { printf ( "-- %d\n" , [ it ] as long[] ) } ( 7..11 ).each { printf ( "-- %5.2f\n" , [ it ] as float[] ) } ( 7..11 ).each { printf ( "-- %5.2g\n" , [ it ] as double[] ) }
self
- any Objectformat
- A format stringarg
- Argument which is referenced by the format specifiers in the format
string. The type of arg
should be one of Object[], List,
int[], short[], byte[], char[], boolean[], long[], float[], or double[].public static String sprintf(Object self, String format, Object arg)
self
- any Objectformat
- A format stringarg
- Argument which is referenced by the format specifiers in the format
string. The type of arg
should be one of Object[], List,
int[], short[], byte[], char[], boolean[], long[], float[], or double[].
public static String inspect(Object self)
self
- any Object
public static void print(Object self, PrintWriter out)
self
- any Objectout
- the PrintWriter used for printingpublic static void println(Object self, PrintWriter out)
self
- any Objectout
- the PrintWriter used for printingpublic static Object invokeMethod(Object object, String method, Object arguments)
object
- any Objectmethod
- the name of the method to callarguments
- the arguments to use
public static boolean isCase(Object caseValue, Object switchValue)
switch( a ) { case b: //some code }"some code" is called when
b.isCase( a )
returns
true
.
caseValue
- the case valueswitchValue
- the switch value
public static boolean isCase(String caseValue, Object switchValue)
switch( str ) { case 'one' : // etc... }Note that this returns
true
for the case where both the
'switch' and 'case' operand is null
.
caseValue
- the case valueswitchValue
- the switch value
public static boolean isCase(CharSequence caseValue, Object switchValue)
caseValue
- the case valueswitchValue
- the switch value
public static boolean isCase(GString caseValue, Object switchValue)
caseValue
- the case valueswitchValue
- the switch value
public static boolean isCase(Class caseValue, Object switchValue)
switch( obj ) { case List : // obj is a list break; case Set : // etc }
caseValue
- the case valueswitchValue
- the switch value
public static boolean isCase(Collection caseValue, Object switchValue)
switch( 3 ) { case [1,3,5]: assert true break default: assert false }
caseValue
- the case valueswitchValue
- the switch value
Collection.contains(java.lang.Object)
public static boolean isCase(Map caseValue, Object switchValue)
switch( 'foo' ) { case [foo:true, bar:false]: assert true break default: assert false }
caseValue
- the case valueswitchValue
- the switch value
public static boolean isCase(Pattern caseValue, Object switchValue)
Pattern
class, which allows
testing a String against a number of regular expressions.
For example:
switch( str ) { case ~/one/ : // the regex 'one' matches the value of str }Note that this returns true for the case where both the pattern and the 'switch' values are
null
.
caseValue
- the case valueswitchValue
- the switch value
public static boolean isCase(Number caseValue, Number switchValue)
compareTo()
method for comparing numbers of different
types.
caseValue
- the case valueswitchValue
- the switch value
public static <T> Iterator<T> unique(Iterator<T> self)
self
- an Iterator
public static <T> Collection<T> unique(Collection<T> self)
assert [1,3] == [1,3,3].unique()
self
- a collection
unique(Collection, boolean)
public static <T> Collection<T> unique(Collection<T> self, boolean mutate)
assert [1,3] == [1,3,3].unique()
def orig = [1, 3, 2, 3] def uniq = orig.unique(false) assert orig == [1, 3, 2, 3] assert uniq == [1, 3, 2]
self
- a collectionmutate
- false will cause a new list containing unique items from the collection to be created, true will mutate collections in place
public static int numberAwareCompareTo(Comparable self, Comparable other)
self
- a Comparableother
- another Comparable
public static <T> Iterator<T> unique(Iterator<T> self, Closure closure)
Comparable.compareTo(java.lang.Object)
or Object.equals(java.lang.Object)
).
If the closure takes two parameters, two items from the Iterator
will be passed as arguments, and the closure should return an
int value (with 0 indicating the items are not unique).
self
- an Iteratorclosure
- a Closure used to determine unique items
public static <T> Collection<T> unique(Collection<T> self, Closure closure)
Comparable.compareTo(java.lang.Object)
or Object.equals(java.lang.Object)
).
If the closure takes two parameters, two items from the collection
will be passed as arguments, and the closure should return an
int value (with 0 indicating the items are not unique).
assert [1,4] == [1,3,4,5].unique { it % 2 }
assert [2,3,4] == [2,3,3,4].unique { a, b -> a <=> b }
self
- a Collectionclosure
- a 1 or 2 arg Closure used to determine unique items
unique(Collection, boolean, Closure)
public static <T> Collection<T> unique(Collection<T> self, boolean mutate, Closure closure)
Comparable.compareTo(java.lang.Object)
or Object.equals(java.lang.Object)
).
If the closure takes two parameters, two items from the collection
will be passed as arguments, and the closure should return an
int value (with 0 indicating the items are not unique).
def orig = [1, 3, 4, 5] def uniq = orig.unique(false) { it % 2 } assert orig == [1, 3, 4, 5] assert uniq == [1, 4]
def orig = [2, 3, 3, 4] def uniq = orig.unique(false) { a, b -> a <=> b } assert orig == [2, 3, 3, 4] assert uniq == [2, 3, 4]
self
- a Collectionmutate
- false will always cause a new list to be created, true will mutate lists in placeclosure
- a 1 or 2 arg Closure used to determine unique items
public static <T> Iterator<T> unique(Iterator<T> self, Comparator<T> comparator)
self
- an Iteratorcomparator
- a Comparator
public static <T> Collection<T> unique(Collection<T> self, Comparator<T> comparator)
class Person {
def fname, lname
String toString() {
return fname + " " + lname
}
}
class PersonComparator implements Comparator {
int compare(Object o1, Object o2) {
Person p1 = (Person) o1
Person p2 = (Person) o2
if (p1.lname != p2.lname)
return p1.lname.compareTo(p2.lname)
else
return p1.fname.compareTo(p2.fname)
}
boolean equals(Object obj) {
return this.equals(obj)
}
}
Person a = new Person(fname:"John", lname:"Taylor")
Person b = new Person(fname:"Clark", lname:"Taylor")
Person c = new Person(fname:"Tom", lname:"Cruz")
Person d = new Person(fname:"Clark", lname:"Taylor")
def list = [a, b, c, d]
List list2 = list.unique(new PersonComparator())
assert( list2 == list && list == [a, b, c] )
self
- a Collectioncomparator
- a Comparator
unique(java.util.Collection, boolean, java.util.Comparator)
public static <T> Collection<T> unique(Collection<T> self, boolean mutate, Comparator<T> comparator)
class Person {
def fname, lname
String toString() {
return fname + " " + lname
}
}
class PersonComparator implements Comparator {
int compare(Object o1, Object o2) {
Person p1 = (Person) o1
Person p2 = (Person) o2
if (p1.lname != p2.lname)
return p1.lname.compareTo(p2.lname)
else
return p1.fname.compareTo(p2.fname)
}
boolean equals(Object obj) {
return this.equals(obj)
}
}
Person a = new Person(fname:"John", lname:"Taylor")
Person b = new Person(fname:"Clark", lname:"Taylor")
Person c = new Person(fname:"Tom", lname:"Cruz")
Person d = new Person(fname:"Clark", lname:"Taylor")
def list = [a, b, c, d]
List list2 = list.unique(false, new PersonComparator())
assert( list2 != list && list2 == [a, b, c] )
self
- a Collectionmutate
- false will always cause a new collection to be created, true will mutate collections in placecomparator
- a Comparator
public static <T> T each(T self, Closure closure)
self
- the object over which we iterateclosure
- the closure applied on each element found
public static <T> T eachWithIndex(T self, Closure closure)
self
- an Objectclosure
- a Closure to operate on each item
public static <K,V> Map<K,V> each(Map<K,V> self, Closure closure)
def result = "" [a:1, b:3].each { key, value -> result += "$key$value" } assert result == "a1b3"
def result = "" [a:1, b:3].each { entry -> result += entry } assert result == "a=1b=3"In general, the order in which the map contents are processed cannot be guaranteed. In practise, specialized forms of Map, e.g. a TreeMap will have its contents processed according to the natural ordering of the map.
self
- the map over which we iterateclosure
- the 1 or 2 arg closure applied on each entry of the map
public static <K,V> Map<K,V> reverseEach(Map<K,V> self, Closure closure)
self
- the map over which we iterateclosure
- the 1 or 2 arg closure applied on each entry of the map
each(Map, Closure)
public static <K,V> Map<K,V> eachWithIndex(Map<K,V> self, Closure closure)
def result = "" [a:1, b:3].eachWithIndex { key, value, index -> result += "$index($key$value)" } assert result == "0(a1)1(b3)"
def result = "" [a:1, b:3].eachWithIndex { entry, index -> result += "$index($entry)" } assert result == "0(a=1)1(b=3)"
self
- the map over which we iterateclosure
- a 2 or 3 arg Closure to operate on each item
public static <T> List<T> reverseEach(List<T> self, Closure closure)
def result = [] [1,2,3].reverseEach { result << it } assert result == [3,2,1]
self
- a Listclosure
- a closure to which each item is passed.
public static <T> T[] reverseEach(T[] self, Closure closure)
self
- an Object arrayclosure
- a closure to which each item is passed
public static boolean every(Object self, Closure closure)
true
for all items in this data structure).
A simple example for a list:
def list = [3,4,5] def greaterThanTwo = list.every { it > 2 }
self
- the object over which we iterateclosure
- the closure predicate used for matching
public static <K,V> boolean every(Map<K,V> self, Closure closure)
def map = [a:1, b:2.0, c:2L] assert !map.every { key, value -> value instanceof Integer } assert map.every { entry -> entry.value instanceof Number }
self
- the map over which we iterateclosure
- the 1 or 2 arg Closure predicate used for matching
public static boolean every(Object self)
true
according to the Groovy Truth.
Equivalent to self.every({element -> element})
self
- the object over which we iterate
public static boolean any(Object self, Closure closure)
self
- the object over which we iterateclosure
- the closure predicate used for matching
public static <K,V> boolean any(Map<K,V> self, Closure<?> closure)
assert [2:3, 4:5, 5:10].any { key, value -> key * 2 == value } assert ![2:3, 4:5, 5:10].any { entry -> entry.key == entry.value * 2 }
self
- the map over which we iterateclosure
- the 1 or 2 arg closure predicate used for matching
public static boolean any(Object self)
self
- the object over which we iterate
public static Collection grep(Object self, Object filter)
isCase(java.lang.Object, java.lang.Object)
method used by switch statements. This method can be used with different
kinds of filters like regular expressions, classes, ranges etc.
Example:
def list = ['a', 'b', 'aa', 'bc', 3, 4.5] assert list.grep( ~/a+/ ) == ['a', 'aa'] assert list.grep( ~/../ ) == ['aa', 'bc'] assert list.grep( Number ) == [ 3, 4.5 ] assert list.grep{ it.toString().size() == 1 } == [ 'a', 'b', 3 ]
self
- the object over which we iteratefilter
- the filter to perform on the object (using the isCase(java.lang.Object, java.lang.Object)
method)
public static Collection grep(Object self)
def items = [1, 2, 0, false, true, '', 'foo', [], [4, 5], null] assert items.grep() == [1, 2, true, 'foo', [4, 5]]
self
- the object over which we iterate
Closure.IDENTITY
public static Number count(Iterator self, Object value)
compareTo(value) == 0
or equals(value)
).
The iterator will become exhausted of elements after determining the count value.
self
- the Iterator from which we count the number of matching occurrencesvalue
- the value being searched for
public static Number count(Iterator self, Closure closure)
Example usage:
assert [2,4,2,1,3,5,2,4,3].toSet().iterator().count{ it % 2 == 0 } == 2
self
- the Iterator from which we count the number of matching occurrencesclosure
- a closure condition
public static Number count(Collection self, Object value)
compareTo(value) == 0
or equals(value)
).
Example usage:
assert [2,4,2,1,3,5,2,4,3].count(4) == 2
self
- the collection within which we count the number of occurrencesvalue
- the value being searched for
public static Number count(Collection self, Closure closure)
Example usage:
assert [2,4,2,1,3,5,2,4,3].count{ it % 2 == 0 } == 5
self
- the collection within which we count the number of occurrencesclosure
- a closure condition
public static Number count(Map self, Closure<?> closure)
Example usage:
assert [a:1, b:1, c:2, d:2].count{ k,v -> k == 'a' || v == 2 } == 3
self
- the map within which we count the number of occurrencesclosure
- a 1 or 2 arg Closure condition applying on the entries
public static Number count(Object[] self, Object value)
compareTo(value) == 0
or equals(value)
).
self
- the array within which we count the number of occurrencesvalue
- the value being searched for
public static Number count(Object[] self, Closure closure)
self
- the array within which we count the number of occurrencesclosure
- a closure condition
public static Number count(int[] self, Object value)
compareTo(value) == 0
or equals(value)
).
self
- the array within which we count the number of occurrencesvalue
- the value being searched for
public static Number count(long[] self, Object value)
compareTo(value) == 0
or equals(value)
).
self
- the array within which we count the number of occurrencesvalue
- the value being searched for
public static Number count(short[] self, Object value)
compareTo(value) == 0
or equals(value)
).
self
- the array within which we count the number of occurrencesvalue
- the value being searched for
public static Number count(char[] self, Object value)
compareTo(value) == 0
or equals(value)
).
self
- the array within which we count the number of occurrencesvalue
- the value being searched for
public static Number count(boolean[] self, Object value)
compareTo(value) == 0
or equals(value)
).
self
- the array within which we count the number of occurrencesvalue
- the value being searched for
public static Number count(double[] self, Object value)
compareTo(value) == 0
or equals(value)
).
self
- the array within which we count the number of occurrencesvalue
- the value being searched for
public static Number count(float[] self, Object value)
compareTo(value) == 0
or equals(value)
).
self
- the array within which we count the number of occurrencesvalue
- the value being searched for
public static Number count(byte[] self, Object value)
compareTo(value) == 0
or equals(value)
).
self
- the array within which we count the number of occurrencesvalue
- the value being searched for
public static <T> List<T> toList(Collection<T> self)
Example usage:
def x = [1,2,3] as HashSet assert x.class == HashSet assert x.toList() instanceof List
self
- a collection
public static <T> List<T> toList(Iterator<T> self)
self
- an iterator
public static <T> List<T> toList(Iterable<T> self)
self
- an Iterable
public static <T> List<T> toList(Enumeration<T> self)
self
- an enumeration
public static <T> List<List<T>> collate(List<T> self, int size)
size
.
Example:
def list = [ 1, 2, 3, 4, 5, 6, 7 ] def coll = list.collate( 3 ) assert coll == [ [ 1, 2, 3 ], [ 4, 5, 6 ], [ 7 ] ]
self
- a Listsize
- the length of each sub-list in the returned list
public static <T> List<List<T>> collate(List<T> self, int size, int step)
size
stepping through the code step
elements for each subList.
Example:
def list = [ 1, 2, 3, 4 ] def coll = list.collate( 3, 1 ) assert coll == [ [ 1, 2, 3 ], [ 2, 3, 4 ], [ 3, 4 ], [ 4 ] ]
self
- a Listsize
- the length of each sub-list in the returned liststep
- the number of elements to step through for each sub-list
public static <T> List<List<T>> collate(List<T> self, int size, boolean keepRemainder)
size
. Any remaining elements in
the list after the subdivision will be dropped if keepRemainder
is false.
Example:
def list = [ 1, 2, 3, 4, 5, 6, 7 ] def coll = list.collate( 3, false ) assert coll == [ [ 1, 2, 3 ], [ 4, 5, 6 ] ]
self
- a Listsize
- the length of each sub-list in the returned listkeepRemainder
- if true, any rmeaining elements are returned as sub-lists. Otherwise they are discarded
public static <T> List<List<T>> collate(List<T> self, int size, int step, boolean keepRemainder)
size
stepping through the code step
elements for each sub-list. Any remaining elements in the list after the subdivision will be dropped if
keepRemainder
is false.
Example:
def list = [ 1, 2, 3, 4 ] assert list.collate( 3, 1, true ) == [ [ 1, 2, 3 ], [ 2, 3, 4 ], [ 3, 4 ], [ 4 ] ] assert list.collate( 3, 1, false ) == [ [ 1, 2, 3 ], [ 2, 3, 4 ] ]
self
- a Listsize
- the length of each sub-list in the returned liststep
- the number of elements to step through for each sub-listkeepRemainder
- if true, any rmeaining elements are returned as sub-lists. Otherwise they are discarded
public static <T> List<T> collect(Object self, Closure<T> transform)
transform
closure, returning a list of transformed values.
Example:
def list = [1, 'a', 1.23, true ] def types = list.collect { it.class } assert types == [Integer, String, BigDecimal, Boolean]
self
- an aggregate Object with an Iterator returning its itemstransform
- the closure used to transform each item of the aggregate object
public static Collection collect(Object self)
assert [1,2,3] == [1,2,3].iterator().collect()
self
- an aggregate Object with an Iterator returning its items
Closure.IDENTITY
public static <T> Collection<T> collect(Object self, Collection<T> collector, Closure<? extends T> transform)
transform
closure
and adding it to the supplied collector
.
self
- an aggregate Object with an Iterator returning its itemscollector
- the Collection to which the transformed values are addedtransform
- the closure used to transform each item of the aggregate object
public static <T> List<T> collect(Collection<?> self, Closure<T> transform)
transform
closure
returning a list of transformed values.
assert [2,4,6] == [1,2,3].collect { it * 2 }
self
- a collectiontransform
- the closure used to transform each item of the collection
public static <T> List<T> collect(Collection<T> self)
assert [1,2,3] == [1,2,3].collect()
self
- a collection
Closure.IDENTITY
public static <T> Collection<T> collect(Collection<?> self, Collection<T> collector, Closure<? extends T> transform)
transform
closure
and adding it to the supplied collector
.
assert [1,2,3] as HashSet == [2,4,5,6].collect(new HashSet()) { (int)(it / 2) }
self
- a collectioncollector
- the Collection to which the transformed values are addedtransform
- the closure used to transform each item of the collection
public static List collectAll(Collection self, Closure transform)
collectNested(Collection, Closure)
public static List collectNested(Collection self, Closure transform)
assert [2,[4,6],[8],[]] == [1,[2,3],[4],[]].collectNested { it * 2 }
self
- a collectiontransform
- the closure used to transform each item of the collection
public static Collection collectAll(Collection self, Collection collector, Closure transform)
collectNested(Collection, Collection, Closure)
public static Collection collectNested(Collection self, Collection collector, Closure transform)
transform
closure. Returns a potentially nested
collection of transformed values.
def x = [1,[2,3],[4],[]].collectNested(new Vector()) { it * 2 } assert x == [2,[4,6],[8],[]] assert x instanceof Vector
self
- a collectioncollector
- an initial Collection to which the transformed values are addedtransform
- the closure used to transform each element of the collection
public static <T> List<T> collectMany(Collection self, Closure<Collection<? extends T>> projection)
def nums = 1..10 def squaresAndCubesOfEvens = nums.collectMany{ it % 2 ? [] : [it**2, it**3] } assert squaresAndCubesOfEvens == [4, 8, 16, 64, 36, 216, 64, 512, 100, 1000] def animals = ['CAT', 'DOG', 'ELEPHANT'] as Set def smallAnimals = animals.collectMany{ it.size() > 3 ? [] : [it.toLowerCase()] } assert smallAnimals == ['cat', 'dog'] def orig = nums as Set def origPlusIncrements = orig.collectMany{ [it, it+1] } assert origPlusIncrements.size() == orig.size() * 2 assert origPlusIncrements.unique().size() == orig.size() + 1
self
- a collectionprojection
- a projecting Closure returning a collection of items
sum(java.util.Collection, groovy.lang.Closure)
public static <T> Collection<T> collectMany(Collection self, Collection<T> collector, Closure<Collection<? extends T>> projection)
collector
.
def animals = ['CAT', 'DOG', 'ELEPHANT'] as Set def smallAnimals = animals.collectMany(['ant', 'bee']){ it.size() > 3 ? [] : [it.toLowerCase()] } assert smallAnimals == ['ant', 'bee', 'cat', 'dog'] def nums = 1..5 def origPlusIncrements = nums.collectMany([] as Set){ [it, it+1] } assert origPlusIncrements.size() == nums.size() + 1
self
- a collectioncollector
- an initial collection to add the projected items toprojection
- a projecting Closure returning a collection of items
public static <T> Collection<T> collectMany(Map<?,?> self, Collection<T> collector, Closure<Collection<? extends T>> projection)
collector
.
def map = [bread:3, milk:5, butter:2] def result = map.collectMany(['x']){ k, v -> k.startsWith('b') ? k.toList() : [] } assert result == ['x', 'b', 'r', 'e', 'a', 'd', 'b', 'u', 't', 't', 'e', 'r']
self
- a mapcollector
- an initial collection to add the projected items toprojection
- a projecting Closure returning a collection of items
public static <T> Collection<T> collectMany(Map<?,?> self, Closure<Collection<? extends T>> projection)
def map = [bread:3, milk:5, butter:2] def result = map.collectMany{ k, v -> k.startsWith('b') ? k.toList() : [] } assert result == ['b', 'r', 'e', 'a', 'd', 'b', 'u', 't', 't', 'e', 'r']
self
- a mapprojection
- a projecting Closure returning a collection of items
public static <T> List<T> collectMany(Object[] self, Closure<Collection<? extends T>> projection)
def nums = [1, 2, 3, 4, 5, 6] as Object[] def squaresAndCubesOfEvens = nums.collectMany{ it % 2 ? [] : [it**2, it**3] } assert squaresAndCubesOfEvens == [4, 8, 16, 64, 36, 216]
self
- an object arrayprojection
- a projecting Closure returning a collection of items
sum(Object[], groovy.lang.Closure)
public static <T> List<T> collectMany(Iterator<Object> self, Closure<Collection<? extends T>> projection)
def numsIter = [1, 2, 3, 4, 5, 6].iterator() def squaresAndCubesOfEvens = numsIter.collectMany{ it % 2 ? [] : [it**2, it**3] } assert squaresAndCubesOfEvens == [4, 8, 16, 64, 36, 216]
self
- an iteratorprojection
- a projecting Closure returning a collection of items
sum(Iterator, groovy.lang.Closure)
public static <T> Collection<T> collect(Map<?,?> self, Collection<T> collector, Closure<? extends T> transform)
transform
closure
returning the collector
with all transformed vakues added to it.
assert [a:1, b:2].collect( [] as HashSet ) { key, value -> key*value } == ["a", "bb"] as Set assert [3:20, 2:30].collect( [] as HashSet ) { entry -> entry.key * entry.value } == [60] as Set
self
- a Mapcollector
- the Collection to which transformed values are addedtransform
- the transformation closure which can take one (Map.Entry) or two (key, value) parameters
public static <T> List<T> collect(Map self, Closure<T> transform)
transform
closure
returning a list of transformed values.
assert [a:1, b:2].collect { key, value -> key*value } == ["a", "bb"] assert [3:20, 2:30].collect { entry -> entry.key * entry.value } == [60, 60]
self
- a Maptransform
- the transformation closure which can take one (Map.Entry) or two (key, value) parameters
public static <K,V> Map<K,V> collectEntries(Map<?,?> self, Map<K,V> collector, Closure<?> transform)
transform
closure
returning a map of the transformed entries.
assert [a:1, b:2].collectEntries( [:] ) { k, v -> [v, k] } == [1:'a', 2:'b'] assert [a:1, b:2].collectEntries( [30:'C'] ) { key, value -> [(value*10): key.toUpperCase()] } == [10:'A', 20:'B', 30:'C']
self
- a Mapcollector
- the Map into which the transformed entries are puttransform
- the closure used for transforming, which can take one (Map.Entry) or two (key, value) parameters and
should return a Map.Entry, a Map or a two-element list containing the resulting key and value
collect(Map, Collection, Closure)
public static Map<?,?> collectEntries(Map<?,?> self, Closure<?> transform)
transform
closure
and returning a map of the transformed entries.
assert [a:1, b:2].collectEntries { key, value -> [value, key] } == [1:'a', 2:'b'] assert [a:1, b:2].collectEntries { key, value -> [(value*10): key.toUpperCase()] } == [10:'A', 20:'B']
self
- a Maptransform
- the closure used for transforming, which can take one (Map.Entry) or two (key, value) parameters and
should return a Map.Entry, a Map or a two-element list containing the resulting key and value
collect(Map, Collection, Closure)
public static <K,V> Map<K,V> collectEntries(Collection<?> self, Closure<?> transform)
transform
closure
and returning a map of the resulting transformed entries.
def letters = "abc" // collect letters with index using list style assert (0..2).collectEntries { index -> [index, letters[index]] } == [0:'a', 1:'b', 2:'c'] // collect letters with index using map style assert (0..2).collectEntries { index -> [(index): letters[index]] } == [0:'a', 1:'b', 2:'c']
self
- a Collectiontransform
- the closure used for transforming, which has an item from self as the parameter and
should return a Map.Entry, a Map or a two-element list containing the resulting key and value
collectEntries(Collection, Map, Closure)
public static <K,V> Map<K,V> collectEntries(Collection<?> self)
[key, value]
tuples or a Map.Entry
.
def nums = [1, 10, 100, 1000] def tuples = nums.collect{ [it, it.toString().size()] } assert tuples == [[1, 1], [10, 2], [100, 3], [1000, 4]] def map = tuples.collectEntries() assert map == [1:1, 10:2, 100:3, 1000:4]
self
- a Collection
collectEntries(Collection, Closure)
public static <K,V> Map<K,V> collectEntries(Collection<?> self, Map<K,V> collector, Closure<?> transform)
def letters = "abc" // collect letters with index assert (0..2).collectEntries( [:] ) { index -> [index, letters[index]] } == [0:'a', 1:'b', 2:'c'] assert (0..2).collectEntries( [4:'d'] ) { index -> [(index+1): letters[index]] } == [1:'a', 2:'b', 3:'c', 4:'d']
self
- a Collectioncollector
- the Map into which the transformed entries are puttransform
- the closure used for transforming, which has an item from self as the parameter and
should return a Map.Entry, a Map or a two-element list containing the resulting key and value
collect(Map, Collection, Closure)
public static <K,V> Map<K,V> collectEntries(Collection<?> self, Map<K,V> collector)
self
- a Collectioncollector
- the Map into which the transformed entries are put
collectEntries(Collection, Map, Closure)
public static <K,V> Map<K,V> collectEntries(Object[] self, Map<K,V> collector, Closure<?> transform)
transform
closure
and returning a map of the resulting transformed entries.
def letters = "abc" def nums = [0, 1, 2] as Integer[] // collect letters with index assert nums.collectEntries( [:] ) { index -> [index, letters[index]] } == [0:'a', 1:'b', 2:'c'] assert nums.collectEntries( [4:'d'] ) { index -> [(index+1): letters[index]] } == [1:'a', 2:'b', 3:'c', 4:'d']
self
- an Object arraycollector
- the Map into which the transformed entries are puttransform
- the closure used for transforming, which has an item from self as the parameter and
should return a Map.Entry, a Map or a two-element list containing the resulting key and value
collect(Map, Collection, Closure)
public static <K,V> Map<K,V> collectEntries(Object[] self, Map<K,V> collector)
self
- an Object arraycollector
- the Map into which the transformed entries are put
collectEntries(Object[], Map, Closure)
public static <K,V> Map<K,V> collectEntries(Object[] self, Closure<?> transform)
transform
closure
and returning a map of the resulting transformed entries.
def letters = "abc" def nums = [0, 1, 2] as Integer[] // collect letters with index using list style assert nums.collectEntries { index -> [index, letters[index]] } == [0:'a', 1:'b', 2:'c'] // collect letters with index using map style assert nums.collectEntries { index -> [(index): letters[index]] } == [0:'a', 1:'b', 2:'c']
self
- a Collectiontransform
- the closure used for transforming, which has an item from self as the parameter and
should return a Map.Entry, a Map or a two-element list containing the resulting key and value
collectEntries(Collection, Map, Closure)
public static <K,V> Map<K,V> collectEntries(Object[] self)
self
- an Object array
collectEntries(Object[], Closure)
public static Object find(Object self, Closure closure)
self
- an Object with an iterator returning its valuesclosure
- a closure condition
public static Object find(Object self)
def items = [null, 0, 0.0, false, '', [], 42, 43] assert items.find() == 42
self
- an Object with an Iterator returning its values
Closure.IDENTITY
public static Object findResult(Object self, Object defaultResult, Closure closure)
self
- an Object with an iterator returning its valuesdefaultResult
- an Object that should be returned if all closure results are nullclosure
- a closure that returns a non-null value when processing should stop
public static Object findResult(Object self, Closure closure)
self
- an Object with an iterator returning its valuesclosure
- a closure that returns a non-null value when processing should stop
public static <T> T find(Collection<T> self, Closure closure)
def list = [1,2,3] assert 2 == list.find { it > 1 }
self
- a Collectionclosure
- a closure condition
public static <T> T find(Collection<T> self)
def items = [null, 0, 0.0, false, '', [], 42, 43] assert items.find() == 42
self
- a Collection
Closure.IDENTITY
public static <T,U extends T,V extends T> T findResult(Collection<?> self, U defaultResult, Closure<V> closure)
def list = [1,2,3] assert "Found 2" == list.findResult("default") { it > 1 ? "Found $it" : null } assert "default" == list.findResult("default") { it > 3 ? "Found $it" : null }
self
- a CollectiondefaultResult
- an Object that should be returned if all closure results are nullclosure
- a closure that returns a non-null value when processing should stop and a value should be returned
public static <T> T findResult(Collection<?> self, Closure<T> closure)
def list = [1,2,3] assert "Found 2" == list.findResult { it > 1 ? "Found $it" : null }
self
- a Collectionclosure
- a closure that returns a non-null value when processing should stop and a value should be returned
public static <T> Collection<T> findResults(Collection<?> self, Closure<T> filteringTransform)
def list = [1,2,3] def result = list.findResults { it > 1 ? "Found $it" : null } assert result == ["Found 2", "Found 3"]
self
- a CollectionfilteringTransform
- a Closure that should return either a non-null transformed value or null for items which should be discarded
public static <T> Collection<T> findResults(Map<?,?> self, Closure<T> filteringTransform)
def map = [a:1, b:2, hi:2, cat:3, dog:2] def result = map.findResults { k, v -> k.size() == v ? "Found $k:$v" : null } assert result == ["Found a:1", "Found hi:2", "Found cat:3"]
self
- a MapfilteringTransform
- a 1 or 2 arg Closure that should return either a non-null transformed value or null for items which should be discarded
public static <K,V> Map.Entry<K,V> find(Map<K,V> self, Closure<?> closure)
assert [a:1, b:3].find { it.value == 3 }.key == "b"
self
- a Mapclosure
- a 1 or 2 arg Closure condition
public static <T,U extends T,V extends T> T findResult(Map<?,?> self, U defaultResult, Closure<V> closure)
assert "Found b:3" == [a:1, b:3].findResult("default") { if (it.value == 3) return "Found ${it.key}:${it.value}" } assert "default" == [a:1, b:3].findResult("default") { if (it.value == 9) return "Found ${it.key}:${it.value}" } assert "Found a:1" == [a:1, b:3].findResult("default") { k, v -> if (k.size() + v == 2) return "Found $k:$v" }
self
- a MapdefaultResult
- an Object that should be returned if all closure results are nullclosure
- a 1 or 2 arg Closure that returns a non-null value when processing should stop and a value should be returned
public static <T> T findResult(Map<?,?> self, Closure<T> closure)
assert "Found b:3" == [a:1, b:3].findResult { if (it.value == 3) return "Found ${it.key}:${it.value}" } assert null == [a:1, b:3].findResult { if (it.value == 9) return "Found ${it.key}:${it.value}" } assert "Found a:1" == [a:1, b:3].findResult { k, v -> if (k.size() + v == 2) return "Found $k:$v" }
self
- a Mapclosure
- a 1 or 2 arg Closure that returns a non-null value when processing should stop and a value should be returned
public static <T> Collection<T> findAll(Collection<T> self, Closure closure)
assert [2,4] == [1,2,3,4].findAll { it % 2 == 0 }
self
- a Collectionclosure
- a closure condition
public static <T> Collection<T> findAll(Collection<T> self)
def items = [1, 2, 0, false, true, '', 'foo', [], [4, 5], null] assert items.findAll() == [1, 2, true, 'foo', [4, 5]]
self
- a Collection
Closure.IDENTITY
public static Collection findAll(Object self, Closure closure)
self
- an Object with an Iterator returning its valuesclosure
- a closure condition
public static Collection findAll(Object self)
def items = [1, 2, 0, false, true, '', 'foo', [], [4, 5], null] assert items.findAll() == [1, 2, true, 'foo', [4, 5]]
self
- an Object with an Iterator returning its values
Closure.IDENTITY
public static boolean containsAll(Collection self, Object[] items)
self
- a Collection to be checked for containmentitems
- array to be checked for containment in this collection
Collection.containsAll(Collection)
public static boolean removeAll(Collection self, Object[] items)
findAll
and grep
when wanting to produce a new list
containing items which don't match some criteria while leaving the original collection unchanged.
self
- a Collection to be modifieditems
- array containing elements to be removed from this collection
Collection.removeAll(Collection)
public static boolean retainAll(Collection self, Object[] items)
grep
and findAll
when wanting to produce a new list
containing items which match some specified items but leaving the original collection unchanged.
self
- a Collection to be modifieditems
- array containing elements to be retained from this collection
Collection.retainAll(Collection)
public static boolean retainAll(Collection self, Closure condition)
findAll
and grep
when wanting to produce a new list
containing items which match some criteria but leaving the original collection unchanged.
self
- a Collection to be modifiedcondition
- a closure condition
Iterator.remove()
public static boolean removeAll(Collection self, Closure condition)
findAll
and grep
when wanting to produce a new list
containing items which don't match some criteria while leaving the original collection unchanged.
self
- a Collection to be modifiedcondition
- a closure condition
Iterator.remove()
public static <T> boolean addAll(Collection<T> self, T[] items)
plus
or the '+' operator if wanting to produce a new collection
containing additional items but while leaving the original collection unchanged.
self
- a Collection to be modifieditems
- array containing elements to be added to this collection
Collection.addAll(Collection)
public static <T> boolean addAll(List<T> self, int index, T[] items)
plus
for similar functionality with copy semantics, i.e. which produces a new
list after adding the additional items at the specified position but leaves the original list unchanged.
self
- a list to be modifieditems
- array containing elements to be added to this collectionindex
- index at which to insert the first element from the
specified array
List.addAll(int, Collection)
public static Collection split(Object self, Closure closure)
self
- an Object with an Iterator returning its valuesclosure
- a closure condition
public static <T> Collection<Collection<T>> split(Collection<T> self, Closure closure)
Example usage:
assert [[2,4],[1,3]] == [1,2,3,4].split { it % 2 == 0 }
self
- a Collection of valuesclosure
- a closure condition
public static List combinations(Collection self)
Example usage:
assert [['a', 'b'],[1, 2, 3]].combinations() == [['a', 1], ['b', 1], ['a', 2], ['b', 2], ['a', 3], ['b', 3]]
self
- a Collection of lists
GroovyCollections.combinations(java.util.Collection)
public static <T> Set<List<T>> subsequences(List<T> self)
Example usage:
def result = [1, 2, 3].subsequences() assert result == [[1, 2, 3], [1, 3], [2, 3], [1, 2], [1], [2], [3]] as Set
self
- the List of items
public static <T> Set<List<T>> permutations(List<T> self)
Example usage:
def result = [1, 2, 3].permutations() assert result == [[3, 2, 1], [3, 1, 2], [1, 3, 2], [2, 3, 1], [2, 1, 3], [1, 2, 3]] as Set
self
- the Collection of items
public static <T> Iterator<List<T>> eachPermutation(Collection<T> self, Closure closure)
Example usage:
def permutations = [] [1, 2, 3].eachPermutation{ permutations << it } assert permutations == [[1, 2, 3], [1, 3, 2], [2, 1, 3], [2, 3, 1], [3, 1, 2], [3, 2, 1]]
self
- the Collection of itemsclosure
- the closure to call for each permutation
public static List transpose(List self)
Example usage:
def result = [['a', 'b'], [1, 2]].transpose() assert result == [['a', 1], ['b', 2]]
def result = [['a', 'b'], [1, 2], [3, 4]].transpose() assert result == [['a', 1, 3], ['b', 2, 4]]
self
- a List of lists
GroovyCollections.transpose(java.util.List)
public static <K,V> Map<K,V> findAll(Map<K,V> self, Closure closure)
If the self
map is one of TreeMap, LinkedHashMap, Hashtable
or Properties, the returned Map will preserve that type, otherwise a HashMap will
be returned.
Example usage:
def result = [a:1, b:2, c:4, d:5].findAll { it.value % 2 == 0 } assert result.every { it instanceof Map.Entry } assert result*.key == ["b", "c"] assert result*.value == [2, 4]
self
- a Mapclosure
- a 1 or 2 arg Closure condition applying on the entries
public static <K,T> Map<K,List<T>> groupBy(Collection<T> self, Closure<K> closure)
Example usage:
assert [0:[2,4,6], 1:[1,3,5]] == [1,2,3,4,5,6].groupBy { it % 2 }
self
- a collection to groupclosure
- a closure mapping entries on keys
public static Map groupBy(Collection self, Object... closures)
Example usage:
def result = [1,2,3,4,5,6].groupBy({ it % 2 }, { it < 4 }) assert result == [1:[(true):[1, 3], (false):[5]], 0:[(true):[2], (false):[4, 6]]]Another example:
def sql = groovy.sql.Sql.newInstance(/* ... */) def data = sql.rows("SELECT * FROM a_table").groupBy({ it.column1 }, { it.column2 }, { it.column3 }) if (data.val1.val2.val3) { // there exists a record where: // a_table.column1 == val1 // a_table.column2 == val2, and // a_table.column3 == val3 } else { // there is no such record }If an empty array of closures is supplied the IDENTITY Closure will be used.
self
- a collection to groupclosures
- an array of closures, each mapping entries on keys
Closure.IDENTITY
public static Map groupBy(Collection self, List<Closure> closures)
Example usage:
def result = [1,2,3,4,5,6].groupBy([{ it % 2 }, { it < 4 }]) assert result == [1:[(true):[1, 3], (false):[5]], 0:[(true):[2], (false):[4, 6]]]Another example:
def sql = groovy.sql.Sql.newInstance(/* ... */) def data = sql.rows("SELECT * FROM a_table").groupBy([{ it.column1 }, { it.column2 }, { it.column3 }]) if (data.val1.val2.val3) { // there exists a record where: // a_table.column1 == val1 // a_table.column2 == val2, and // a_table.column3 == val3 } else { // there is no such record }If an empty list of closures is supplied the IDENTITY Closure will be used.
self
- a collection to groupclosures
- a list of closures, each mapping entries on keys
Closure.IDENTITY
public static <K> Map<K,Integer> countBy(Collection self, Closure<K> closure)
Example usage:
assert [0:2, 1:3] == [1,2,3,4,5].countBy { it % 2 }
self
- a collection to group and countclosure
- a closure mapping items to the frequency keys
public static <K> Map<K,Integer> countBy(Object[] self, Closure<K> closure)
Example usage:
assert ([1,2,2,2,3] as Object[]).countBy{ it % 2 } == [1:2, 0:3]
self
- an object array to group and countclosure
- a closure mapping items to the frequency keys
countBy(Collection, Closure)
public static <K> Map<K,Integer> countBy(Iterator self, Closure<K> closure)
Example usage:
assert [1,2,2,2,3].toSet().iterator().countBy{ it % 2 } == [1:2, 0:1]
self
- an iterator to group and countclosure
- a closure mapping items to the frequency keys
countBy(Collection, Closure)
public static <G,K,V> Map<G,List<Map.Entry<K,V>>> groupEntriesBy(Map<K,V> self, Closure<G> closure)
def result = [a:1,b:2,c:3,d:4,e:5,f:6].groupEntriesBy { it.value % 2 } assert result[0]*.key == ["b", "d", "f"] assert result[1]*.value == [1, 3, 5]
self
- a map to groupclosure
- a 1 or 2 arg Closure mapping entries on keys
public static <G,K,V> Map<G,Map<K,V>> groupBy(Map<K,V> self, Closure<G> closure)
If the self
map is one of TreeMap, Hashtable or Properties,
the returned Map will preserve that type, otherwise a LinkedHashMap will
be returned.
def result = [a:1,b:2,c:3,d:4,e:5,f:6].groupBy { it.value % 2 } assert result == [0:[b:2, d:4, f:6], 1:[a:1, c:3, e:5]]
self
- a map to groupclosure
- a closure mapping entries on keys
public static Map<Object,Map> groupBy(Map self, Object... closures)
If the self
map is one of TreeMap, Hashtable, or Properties,
the returned Map will preserve that type, otherwise a LinkedHashMap will
be returned.
def result = [a:1,b:2,c:3,d:4,e:5,f:6].groupBy({ it.value % 2 }, { it.key.next() }) assert result == [1:[b:[a:1], d:[c:3], f:[e:5]], 0:[c:[b:2], e:[d:4], g:[f:6]]]If an empty array of closures is supplied the IDENTITY Closure will be used.
self
- a map to groupclosures
- an array of closures that map entries on keys
Closure.IDENTITY
public static Map<Object,Map> groupBy(Map self, List<Closure> closures)
If the self
map is one of TreeMap, Hashtable, or Properties,
the returned Map will preserve that type, otherwise a LinkedHashMap will
be returned.
def result = [a:1,b:2,c:3,d:4,e:5,f:6].groupBy([{ it.value % 2 }, { it.key.next() }]) assert result == [1:[b:[a:1], d:[c:3], f:[e:5]], 0:[c:[b:2], e:[d:4], g:[f:6]]]If an empty list of closures is supplied the IDENTITY Closure will be used.
self
- a map to groupclosures
- a list of closures that map entries on keys
Closure.IDENTITY
public static <K> Map<K,Integer> countBy(Map self, Closure<K> closure)
def result = [a:1,b:2,c:3,d:4,e:5].countBy { it.value % 2 } assert result == [0:2, 1:3]
self
- a map to group and countclosure
- a closure mapping entries to frequency count keys
protected static <K,T> void groupAnswer(Map<K,List<T>> answer, T element, K value)
answer
- the map containing the resultselement
- the element to be placedvalue
- the value according to which the element will be placedprotected static <T> T callClosureForMapEntry(Closure<T> closure, Map.Entry entry)
protected static <T> T callClosureForLine(Closure<T> closure, String line, int counter)
protected static <T> T callClosureForMapEntryAndCounter(Closure<T> closure, Map.Entry entry, int counter)
public static <T,V extends T> T inject(Collection<T> self, Closure<V> closure)
assert 1 * 2 * 3 * 4 == [ 1, 2, 3, 4 ].inject { acc, val -> acc * val } assert ['b'] == [['a','b'], ['b','c'], ['d','b']].inject { acc, val -> acc.intersect( val ) } LinkedHashSet set = [ 't', 'i', 'm' ] assert 'tim' == set.inject { a, b -> a + b }
self
- a Collectionclosure
- a closure
NoSuchElementException
- if the collection is empty.inject(Collection, Object, Closure)
public static <T,U extends T,V extends T> T inject(Collection self, U initialValue, Closure<V> closure)
assert 1*1*2*3*4 == [1,2,3,4].inject(1) { acc, val -> acc * val } assert 0+1+2+3+4 == [1,2,3,4].inject(0) { acc, val -> acc + val } assert 'The quick brown fox' == ['quick', 'brown', 'fox'].inject('The') { acc, val -> acc + ' ' + val } assert 'bat' == ['rat', 'bat', 'cat'].inject('zzz') { min, next -> next < min ? next : min } def max = { a, b -> [a, b].max() } def animals = ['bat', 'rat', 'cat'] assert 'rat' == animals.inject('aaa', max)Visual representation of the last example above:
initVal animals[0] v v max('aaa', 'bat') => 'bat' animals[1] v v max('bat', 'rat') => 'rat' animals[2] v v max('rat', 'cat') => 'rat'
self
- a CollectioninitialValue
- some initial valueclosure
- a closure
public static <T,U extends T,V extends T> T inject(Map<?,?> self, U initialValue, Closure<V> closure)
def map = [a:1, b:2, c:3] assert map.inject([]) { list, k, v -> list + [k] * v } == ['a', 'b', 'b', 'c', 'c', 'c']
self
- a MapinitialValue
- some initial valueclosure
- a 2 or 3 arg Closure
public static <T,U extends T,V extends T> T inject(Iterator self, U initialValue, Closure<V> closure)
self
- an IteratorinitialValue
- some initial valueclosure
- a closure
inject(Collection, Object, Closure)
public static <T,V extends T> T inject(Object self, Closure<V> closure)
self
- an Objectclosure
- a closure
NoSuchElementException
- if the collection is empty.inject(Collection, Object, Closure)
public static <T,U extends T,V extends T> T inject(Object self, U initialValue, Closure<V> closure)
self
- an ObjectinitialValue
- some initial valueclosure
- a closure
inject(Collection, Object, Closure)
public static <T,V extends T> T inject(Object[] self, Closure<V> closure)
self
- an Object[]closure
- a closure
NoSuchElementException
- if the array is empty.inject(Object[], Object, Closure)
public static <T,U extends T,V extends T> T inject(Object[] self, U initialValue, Closure<V> closure)
self
- an Object[]initialValue
- some initial valueclosure
- a closure
inject(Collection, Object, Closure)
public static Object sum(Collection self)
assert 1+2+3+4 == [1,2,3,4].sum()
self
- Collection of values to add together
public static Object sum(Object[] self)
self
- The array of values to add together
sum(java.util.Collection)
public static Object sum(Iterator<Object> self)
self
- an Iterator for the values to add together
public static Object sum(Collection self, Object initialValue)
assert 5+1+2+3+4 == [1,2,3,4].sum(5)
self
- a collection of values to suminitialValue
- the items in the collection will be summed to this initial value
public static Object sum(Object[] self, Object initialValue)
self
- an array of values to suminitialValue
- the items in the array will be summed to this initial value
public static Object sum(Iterator<Object> self, Object initialValue)
self
- an Iterator for the values to add togetherinitialValue
- the items in the collection will be summed to this initial value
public static Object sum(Collection self, Closure closure)
coll.sum(closure)
is equivalent to:
coll.collect(closure).sum()
.
assert 4+6+10+12 == [2,3,5,6].sum() { it * 2 }
self
- a Collectionclosure
- a single parameter closure that returns a numeric value.
public static Object sum(Object[] self, Closure closure)
array.sum(closure)
is equivalent to:
array.collect(closure).sum()
.
self
- An arrayclosure
- a single parameter closure that returns a numeric value.
public static Object sum(Iterator<Object> self, Closure closure)
iter.sum(closure)
is equivalent to:
iter.collect(closure).sum()
. The iterator will become
exhausted of elements after determining the sum value.
self
- An Iteratorclosure
- a single parameter closure that returns a numeric value.
public static Object sum(Collection self, Object initialValue, Closure closure)
coll.sum(initVal, closure)
is equivalent to:
coll.collect(closure).sum(initVal)
.
assert 50+4+6+10+12 == [2,3,5,6].sum(50) { it * 2 }
self
- a Collectionclosure
- a single parameter closure that returns a numeric value.initialValue
- the closure results will be summed to this initial value
public static Object sum(Object[] self, Object initialValue, Closure closure)
array.sum(initVal, closure)
is equivalent to:
array.collect(closure).sum(initVal)
.
self
- an arrayclosure
- a single parameter closure that returns a numeric value.initialValue
- the closure results will be summed to this initial value
public static Object sum(Iterator<Object> self, Object initialValue, Closure closure)
iter.sum(initVal, closure)
is equivalent to:
iter.collect(closure).sum(initVal)
. The iterator will become
exhausted of elements after determining the sum value.
self
- an Iteratorclosure
- a single parameter closure that returns a numeric value.initialValue
- the closure results will be summed to this initial value
public static String join(Iterator<Object> self, String separator)
toString()
representation of each
item from the iterator, with the given String as a separator between
each item. The iterator will become exhausted of elements after
determining the resulting conjoined value.
self
- an Iterator of itemsseparator
- a String separator
public static String join(Collection self, String separator)
toString()
representation of each
item in this collection, with the given String as a separator between
each item.
assert "1, 2, 3" == [1,2,3].join(", ")
self
- a Collection of objectsseparator
- a String separator
public static String join(Object[] self, String separator)
toString()
representation of each
items in this array, with the given String as a separator between each
item.
self
- an array of Objectseparator
- a String separator
public static <T> T min(Collection<T> self)
assert 2 == [4,2,5].min()
self
- a Collection
GroovyCollections.min(java.util.Collection)
public static <T> T min(Iterator<T> self)
self
- an Iterator
min(java.util.Collection)
public static <T> T min(T[] self)
self
- an Object array
min(java.util.Collection)
public static <T> T min(Collection<T> self, Comparator<T> comparator)
assert "hi" == ["hello","hi","hey"].min( { a, b -> a.length() <=> b.length() } as Comparator )
self
- a Collectioncomparator
- a Comparator
public static <T> T min(Iterator<T> self, Comparator<T> comparator)
self
- an Iteratorcomparator
- a Comparator
min(java.util.Collection, java.util.Comparator)
public static <T> T min(T[] self, Comparator<T> comparator)
self
- an Object arraycomparator
- a Comparator
min(java.util.Collection, java.util.Comparator)
public static <T> T min(Collection<T> self, Closure closure)
assert "hi" == ["hello","hi","hey"].min { it.length() }
def lastDigit = { a, b -> a % 10 <=> b % 10 } assert [19, 55, 91].min(lastDigit) == 91
def pets = ['dog', 'cat', 'anaconda'] def shortestName = pets.min{ it.size() } // one of 'dog' or 'cat' assert shortestName.size() == 3
self
- a Collectionclosure
- a 1 or 2 arg Closure used to determine the correct ordering
public static <K,V> Map.Entry<K,V> min(Map<K,V> self, Closure closure)
def zoo = [monkeys:6, lions:5, tigers:7] def leastCommonEntry = zoo.min{ it.value } assert leastCommonEntry.value == 5 def mostCommonEntry = zoo.min{ a, b -> b.value <=> a.value } // double negative! assert mostCommonEntry.value == 7Edge case for multiple min values:
def zoo = [monkeys:6, lions:5, tigers:7] def lastCharOfName = { e -> e.key[-1] } def ans = zoo.min(lastCharOfName) // some random entry assert lastCharOfName(ans) == 's'
self
- a Mapclosure
- a 1 or 2 arg Closure used to determine the correct ordering
public static <K,V> Map.Entry<K,V> max(Map<K,V> self, Closure closure)
def zoo = [monkeys:6, lions:5, tigers:7] def mostCommonEntry = zoo.max{ it.value } assert mostCommonEntry.value == 7 def leastCommonEntry = zoo.max{ a, b -> b.value <=> a.value } // double negative! assert leastCommonEntry.value == 5Edge case for multiple max values:
def zoo = [monkeys:6, lions:5, tigers:7] def lengthOfNamePlusNumber = { e -> e.key.size() + e.value } def ans = zoo.max(lengthOfNamePlusNumber) // one of [monkeys:6, tigers:7] assert lengthOfNamePlusNumber(ans) == 13
self
- a Mapclosure
- a 1 or 2 arg Closure used to determine the correct ordering
public static <T> T min(Iterator<T> self, Closure closure)
self
- an Iteratorclosure
- a Closure used to determine the correct ordering
min(java.util.Collection, groovy.lang.Closure)
public static <T> T min(T[] self, Closure closure)
self
- an Object arrayclosure
- a Closure used to determine the correct ordering
min(java.util.Collection, groovy.lang.Closure)
public static <T> T max(Collection<T> self)
assert 5 == [2,3,1,5,4].max()
self
- a Collection
GroovyCollections.max(java.util.Collection)
public static <T> T max(Iterator<T> self)
self
- an Iterator
GroovyCollections.max(java.util.Collection)
public static <T> T max(T[] self)
self
- an Object array
max(java.util.Collection)
public static <T> T max(Collection<T> self, Closure closure)
assert "hello" == ["hello","hi","hey"].max { it.length() }
assert "hello" == ["hello","hi","hey"].max { a, b -> a.length() <=> b.length() }
def pets = ['dog', 'elephant', 'anaconda'] def longestName = pets.max{ it.size() } // one of 'elephant' or 'anaconda' assert longestName.size() == 8
self
- a Collectionclosure
- a 1 or 2 arg Closure used to determine the correct ordering
public static <T> T max(Iterator<T> self, Closure closure)
self
- an Iteratorclosure
- a Closure used to determine the correct ordering
max(java.util.Collection, groovy.lang.Closure)
public static <T> T max(T[] self, Closure closure)
self
- an Object arrayclosure
- a Closure used to determine the correct ordering
max(java.util.Collection, groovy.lang.Closure)
public static <T> T max(Collection<T> self, Comparator<T> comparator)
assert "hello" == ["hello","hi","hey"].max( { a, b -> a.length() <=> b.length() } as Comparator )
self
- a Collectioncomparator
- a Comparator
public static <T> T max(Iterator<T> self, Comparator<T> comparator)
self
- an Iteratorcomparator
- a Comparator
public static <T> T max(T[] self, Comparator<T> comparator)
self
- an Object arraycomparator
- a Comparator
public static int size(Iterator self)
size()
method for Iterator
.
The iterator will become exhausted of elements after determining the size value.
self
- an Iterator
public static int size(String text)
size()
method for String
.
text
- a String
public static int size(CharSequence text)
size()
method for CharSequence
.
text
- a CharSequence
public static int size(StringBuffer buffer)
size()
method for StringBuffer
.
buffer
- a StringBuffer
public static long size(File self)
size()
method for File
.
self
- a file object
public static long size(Matcher self)
size()
method for Matcher
.
self
- a matcher object
public static int size(Object[] self)
size()
method for an array.
self
- an Array of objects
public static CharSequence getAt(CharSequence text, int index)
text
- a CharSequenceindex
- the index of the Character to get
public static String getAt(String text, int index)
text
- a Stringindex
- the index of the Character to get
public static CharSequence getAt(CharSequence text, Range range)
text
- a CharSequencerange
- a Range
public static CharSequence getAt(CharSequence text, IntRange range)
text
- a CharSequencerange
- an IntRange
public static CharSequence getAt(CharSequence text, EmptyRange range)
text
- a CharSequencerange
- an EmptyRange
public static String getAt(String text, IntRange range)
text
- a Stringrange
- an IntRange
public static String getAt(String text, EmptyRange range)
text
- a Stringrange
- an EmptyRange
public static String getAt(String text, Range range)
text
- a Stringrange
- a Range
public static String reverse(String self)
self
- a String
StringBuilder.reverse()
public static CharSequence reverse(CharSequence self)
self
- a CharSequence
reverse(String)
public static String stripMargin(String self)
Strip leading whitespace/control characters followed by '|' from every line in a String.
assert 'ABC\n123\n456' == '''ABC |123 |456'''.stripMargin()
self
- The String to strip the margin from
stripMargin(String, char)
public static CharSequence stripMargin(CharSequence self)
Strip leading whitespace/control characters followed by '|' from every line in a CharSequence.
self
- The CharSequence to strip the margin from
stripMargin(CharSequence, char)
public static String stripMargin(String self, String marginChar)
Strip leading whitespace/control characters followed by marginChar from every line in a String.
self
- The String to strip the margin frommarginChar
- Any character that serves as margin delimiter
stripMargin(String, char)
public static String stripMargin(CharSequence self, CharSequence marginChar)
Strip leading whitespace/control characters followed by marginChar from every line in a CharSequence.
self
- The CharSequence to strip the margin frommarginChar
- Any character that serves as margin delimiter
stripMargin(String, String)
public static String stripMargin(String self, char marginChar)
Strip leading whitespace/control characters followed by marginChar from every line in a String.
assert 'ABC\n123\n456' == '''ABC *123 *456'''.stripMargin('*')
self
- The String to strip the margin frommarginChar
- Any character that serves as margin delimiter
public static CharSequence stripMargin(CharSequence self, char marginChar)
Strip leading whitespace/control characters followed by marginChar from every line in a String.
self
- The CharSequence to strip the margin frommarginChar
- Any character that serves as margin delimiter
stripMargin(String, char)
public static String stripIndent(String self)
Strip leading spaces from every line in a String. The line with the least number of leading spaces determines the number to remove. Lines only containing whitespace are ignored when calculating the number of leading spaces to strip.
assert ' A\n B\nC' == ' A\n B\n C'.stripIndent()
self
- The String to strip the leading spaces from
stripIndent(String, int)
public static CharSequence stripIndent(CharSequence self)
Strip leading spaces from every line in a CharSequence. The line with the least number of leading spaces determines the number to remove. Lines only containing whitespace are ignored when calculating the number of leading spaces to strip.
self
- The CharSequence to strip the leading spaces from
stripIndent(String)
public static boolean isAllWhitespace(String self)
self
- The String to check the characters in
Character.isWhitespace(char)
public static boolean isAllWhitespace(CharSequence self)
self
- The CharSequence to check the characters in
isAllWhitespace(String)
public static String stripIndent(String self, int numChars)
Strip numChar leading characters from every line in a String.
assert 'DEF\n456' == '''ABCDEF\n123456'''.stripIndent(3)
self
- The String to strip the characters fromnumChars
- The number of characters to strip
public static CharSequence stripIndent(CharSequence self, int numChars)
Strip numChar leading characters from every line in a CharSequence.
self
- The CharSequence to strip the characters fromnumChars
- The number of characters to strip
public static URL toURL(String self) throws MalformedURLException
self
- the String representing a URL
MalformedURLException
- is thrown if the URL is not well formed.public static URL toURL(CharSequence self) throws MalformedURLException
self
- the CharSequence representing a URL
MalformedURLException
- is thrown if the URL is not well formed.public static URI toURI(String self) throws URISyntaxException
self
- the String representing a URI
URISyntaxException
- is thrown if the URI is not well formed.public static URI toURI(CharSequence self) throws URISyntaxException
self
- the CharSequence representing a URI
URISyntaxException
- is thrown if the URI is not well formed.public static Pattern bitwiseNegate(String self)
self
- a String to convert into a regular expression
public static Pattern bitwiseNegate(CharSequence self)
self
- a String to convert into a regular expression
public static String replaceFirst(String self, Pattern pattern, String replacement)
Matcher.replaceFirst(java.lang.String)
.
Use Matcher.quoteReplacement(java.lang.String)
to suppress the special
meaning of these characters, if desired.
assert "foo".replaceFirst('o', 'X') == 'fXo'
self
- the string that is to be matchedpattern
- the regex Pattern to which the string of interest is to be matchedreplacement
- the string to be substituted for the first match
String.replaceFirst(java.lang.String, java.lang.String)
public static CharSequence replaceFirst(CharSequence self, Pattern pattern, CharSequence replacement)
self
- the CharSequence that is to be matchedpattern
- the regex Pattern to which the CharSequence of interest is to be matchedreplacement
- the CharSequence to be substituted for the first match
replaceFirst(String, Pattern, String)
public static String replaceAll(String self, Pattern pattern, String replacement)
Note that backslashes (\) and dollar signs ($) in the
replacement string may cause the results to be different than if it were
being treated as a literal replacement string; see
Matcher.replaceAll(java.lang.String)
.
Use Matcher.quoteReplacement(java.lang.String)
to suppress the special
meaning of these characters, if desired.
assert "foo".replaceAll('o', 'X') == 'fXX'
self
- the string that is to be matchedpattern
- the regex Pattern to which the string of interest is to be matchedreplacement
- the string to be substituted for the first match
String.replaceAll(java.lang.String, java.lang.String)
public static CharSequence replaceAll(CharSequence self, Pattern pattern, CharSequence replacement)
self
- the CharSequence that is to be matchedpattern
- the regex Pattern to which the CharSequence of interest is to be matchedreplacement
- the CharSequence to be substituted for the first match
replaceAll(String, Pattern, String)
public static String tr(String self, String sourceSet, String replacementSet) throws ClassNotFoundException
assert 'hello'.tr('aeiou', 'AEIOU') == 'hEllO'A character range using regex-style syntax can also be used, e.g. here is an example which converts a word from lower to uppercase:
assert 'hello'.tr('a-z', 'A-Z') == 'HELLO'Hyphens at the start or end of sourceSet or replacementSet are treated as normal hyphens and are not considered to be part of a range specification. Similarly, a hyphen immediately after an earlier range is treated as a normal hyphen. So, '-x', 'x-' have no ranges while 'a-c-e' has the range 'a-c' plus the '-' character plus the 'e' character. Unlike the unix tr command, Groovy's tr command supports reverse ranges, e.g.:
assert 'hello'.tr('z-a', 'Z-A') == 'HELLO'If replacementSet is smaller than sourceSet, then the last character from replacementSet is used as the replacement for all remaining source characters as shown here:
assert 'Hello World!'.tr('a-z', 'A') == 'HAAAA WAAAA!'If sourceSet contains repeated characters, the last specified replacement is used as shown here:
assert 'Hello World!'.tr('lloo', '1234') == 'He224 W4r2d!'The functionality provided by tr can be achieved using regular expressions but tr provides a much more compact notation and efficient implementation for certain scenarios.
self
- the string that is to be translatedsourceSet
- the set of characters to translate fromreplacementSet
- the set of replacement characters
ClassNotFoundException
StringUtil.tr(String, String, String)
public static CharSequence tr(CharSequence self, CharSequence sourceSet, CharSequence replacementSet) throws ClassNotFoundException
self
- the CharSequence that is to be translatedsourceSet
- the set of characters to translate fromreplacementSet
- the set of replacement characters
ClassNotFoundException
tr(String, String, String)
public static boolean matches(String self, Pattern pattern)
self
- the string that is to be matchedpattern
- the regex Pattern to which the string of interest is to be matched
String.matches(java.lang.String)
public static boolean matches(CharSequence self, Pattern pattern)
self
- the CharSequence that is to be matchedpattern
- the regex Pattern to which the string of interest is to be matched
String.matches(java.lang.String)
public static String find(String self, String regex)
For example, if the regex doesn't match the result is null:
assert null == "New York, NY".find(/\d{5}/)
If it does match, we get the matching string back:
assert "10292" == "New York, NY 10292-0098".find(/\d{5}/)
If we have capture groups in our expression, we still get back the full match
assert "10292-0098" == "New York, NY 10292-0098".find(/(\d{5})-?(\d{4})/)
self
- a Stringregex
- the capturing regex
public static CharSequence find(CharSequence self, CharSequence regex)
self
- a CharSequenceregex
- the capturing regex
find(String, Pattern)
public static String find(String self, Pattern pattern)
For example, if the pattern doesn't match the result is null:
assert null == "New York, NY".find(~/\d{5}/)
If it does match, we get the matching string back:
assert "10292" == "New York, NY 10292-0098".find(~/\d{5}/)
If we have capture groups in our expression, the groups are ignored and we get back the full match:
assert "10292-0098" == "New York, NY 10292-0098".find(~/(\d{5})-?(\d{4})/)If you need to work with capture groups, then use the closure version of this method or use Groovy's matcher operators or use eachMatch.
self
- a Stringpattern
- the compiled regex Pattern
public static CharSequence find(CharSequence self, Pattern pattern)
self
- a CharSequencepattern
- the compiled regex Pattern
find(String, Pattern)
public static String find(String self, String regex, Closure closure)
For example, if the regex doesn't match, the result is null:
assert null == "New York, NY".find(~/\d{5}/) { match -> return "-$match-"}
If it does match and we don't have any capture groups in our regex, there is a single parameter on the closure that the match gets passed to:
assert "-10292-" == "New York, NY 10292-0098".find(~/\d{5}/) { match -> return "-$match-"}
If we have capture groups in our expression, our closure has one parameter for the match, followed by one for each of the capture groups:
assert "10292" == "New York, NY 10292-0098".find(~/(\d{5})-?(\d{4})/) { match, zip, plusFour -> assert match == "10292-0098" assert zip == "10292" assert plusFour == "0098" return zip }
If we have capture groups in our expression, and our closure has one parameter, the closure will be passed an array with the first element corresponding to the whole match, followed by an element for each of the capture groups:
assert "10292" == "New York, NY 10292-0098".find(~/(\d{5})-?(\d{4})/) { match, zip, plusFour -> assert array[0] == "10292-0098" assert array[1] == "10292" assert array[2] == "0098" return array[1] }
If a capture group is optional, and doesn't match, then the corresponding value for that capture group passed to the closure will be null as illustrated here:
assert "2339999" == "adsf 233-9999 adsf".find(~/(\d{3})?-?(\d{3})-(\d{4})/) { match, areaCode, exchange, stationNumber -> assert "233-9999" == match assert null == areaCode assert "233" == exchange assert "9999" == stationNumber return "$exchange$stationNumber" }
self
- a Stringregex
- the capturing regex stringclosure
- the closure that will be passed the full match, plus each of the capturing groups
public static CharSequence find(CharSequence self, CharSequence regex, Closure closure)
self
- a CharSequenceregex
- the capturing regex CharSequenceclosure
- the closure that will be passed the full match, plus each of the capturing groups
find(String, Pattern, Closure)
public static String find(String self, Pattern pattern, Closure closure)
For example, if the pattern doesn't match, the result is null:
assert null == "New York, NY".find(~/\d{5}/) { match -> return "-$match-"}
If it does match and we don't have any capture groups in our regex, there is a single parameter on the closure that the match gets passed to:
assert "-10292-" == "New York, NY 10292-0098".find(~/\d{5}/) { match -> return "-$match-"}
If we have capture groups in our expression, our closure has one parameter for the match, followed by one for each of the capture groups:
assert "10292" == "New York, NY 10292-0098".find(~/(\d{5})-?(\d{4})/) { match, zip, plusFour -> assert match == "10292-0098" assert zip == "10292" assert plusFour == "0098" return zip }
If we have capture groups in our expression, and our closure has one parameter, the closure will be passed an array with the first element corresponding to the whole match, followed by an element for each of the capture groups:
assert "10292" == "New York, NY 10292-0098".find(~/(\d{5})-?(\d{4})/) { match, zip, plusFour -> assert array[0] == "10292-0098" assert array[1] == "10292" assert array[2] == "0098" return array[1] }
If a capture group is optional, and doesn't match, then the corresponding value for that capture group passed to the closure will be null as illustrated here:
assert "2339999" == "adsf 233-9999 adsf".find(~/(\d{3})?-?(\d{3})-(\d{4})/) { match, areaCode, exchange, stationNumber -> assert "233-9999" == match assert null == areaCode assert "233" == exchange assert "9999" == stationNumber return "$exchange$stationNumber" }
self
- a Stringpattern
- the compiled regex Patternclosure
- the closure that will be passed the full match, plus each of the capturing groups
public static CharSequence find(CharSequence self, Pattern pattern, Closure closure)
public static List<String> findAll(String self, String regex)
For example, if the regex doesn't match, it returns an empty list:
assert [] == "foo".findAll(/(\w*) Fish/)
Any regular expression matches are returned in a list, and all regex capture groupings are ignored, only the full match is returned:
def expected = ["One Fish", "Two Fish", "Red Fish", "Blue Fish"] assert expected == "One Fish, Two Fish, Red Fish, Blue Fish".findAll(/(\w*) Fish/)If you need to work with capture groups, then use the closure version of this method or use Groovy's matcher operators or use eachMatch.
self
- a Stringregex
- the capturing regex String
public static List<CharSequence> findAll(CharSequence self, CharSequence regex)
self
- a CharSequenceregex
- the capturing regex CharSequence
findAll(String, String)
public static List<String> findAll(String self, Pattern pattern)
For example, if the pattern doesn't match, it returns an empty list:
assert [] == "foo".findAll(~/(\w*) Fish/)
Any regular expression matches are returned in a list, and all regex capture groupings are ignored, only the full match is returned:
def expected = ["One Fish", "Two Fish", "Red Fish", "Blue Fish"] assert expected == "One Fish, Two Fish, Red Fish, Blue Fish".findAll(~/(\w*) Fish/)
self
- a Stringpattern
- the compiled regex Pattern
public static List<CharSequence> findAll(CharSequence self, Pattern pattern)
self
- a CharSequencepattern
- the compiled regex Pattern
findAll(String, Pattern)
public static <T> List<T> findAll(String self, String regex, Closure<T> closure)
For example, if the regex doesn't match, it returns an empty list:
assert [] == "foo".findAll(/(\w*) Fish/) { match, firstWord -> return firstWord }
Any regular expression matches are passed to the closure, if there are no capture groups, there will be one parameter for the match:
assert ["couldn't", "wouldn't"] == "I could not, would not, with a fox.".findAll(/.ould/) { match -> "${match}n't"}
If there are capture groups, the first parameter will be the match followed by one parameter for each capture group:
def orig = "There's a Wocket in my Pocket" assert ["W > Wocket", "P > Pocket"] == orig.findAll(/(.)ocket/) { match, firstLetter -> "$firstLetter > $match" }
self
- a Stringregex
- the capturing regex Stringclosure
- will be passed the full match plus each of the capturing groups
public static <T> List<T> findAll(CharSequence self, CharSequence regex, Closure<T> closure)
self
- a CharSequenceregex
- the capturing regex CharSequenceclosure
- will be passed the full match plus each of the capturing groups
findAll(String, String, Closure)
public static <T> List<T> findAll(String self, Pattern pattern, Closure<T> closure)
For example, if the pattern doesn't match, it returns an empty list:
assert [] == "foo".findAll(~/(\w*) Fish/) { match, firstWord -> return firstWord }
Any regular expression matches are passed to the closure, if there are no capture groups, there will be one parameter for the match:
assert ["couldn't", "wouldn't"] == "I could not, would not, with a fox.".findAll(~/.ould/) { match -> "${match}n't"}
If there are capture groups, the first parameter will be the match followed by one parameter for each capture group:
def orig = "There's a Wocket in my Pocket" assert ["W > Wocket", "P > Pocket"] == orig.findAll(~/(.)ocket/) { match, firstLetter -> "$firstLetter > $match" }
self
- a Stringpattern
- the compiled regex Patternclosure
- will be passed the full match plus each of the capturing groups
public static <T> List<T> findAll(CharSequence self, Pattern pattern, Closure<T> closure)
self
- a CharSequencepattern
- the compiled regex Patternclosure
- will be passed the full match plus each of the capturing groups
findAll(String, Pattern, Closure)
public static String replaceAll(String self, String regex, Closure closure)
For examples,
assert "hellO wOrld" == "hello world".replaceAll("(o)") { it[0].toUpperCase() } assert "FOOBAR-FOOBAR-" == "foobar-FooBar-".replaceAll("(([fF][oO]{2})[bB]ar)", { Object[] it -> it[0].toUpperCase() }) Here, it[0] is the global string of the matched group it[1] is the first string in the matched group it[2] is the second string in the matched group assert "FOO-FOO-" == "foobar-FooBar-".replaceAll("(([fF][oO]{2})[bB]ar)", { x, y, z -> z.toUpperCase() }) Here, x is the global string of the matched group y is the first string in the matched group z is the second string in the matched group
Note that unlike String.replaceAll(String regex, String replacement), where the replacement string treats '$' and '\' specially (for group substitution), the result of the closure is converted to a string and that value is used literally for the replacement.
self
- a Stringregex
- the capturing regexclosure
- the closure to apply on each captured group
PatternSyntaxException
- if the regular expression's syntax is invalidMatcher.quoteReplacement(java.lang.String)
,
replaceAll(String, Pattern, Closure)
public static CharSequence replaceAll(CharSequence self, CharSequence regex, Closure closure)
self
- a CharSequenceregex
- the capturing regexclosure
- the closure to apply on each captured group
PatternSyntaxException
- if the regular expression's syntax is invalidreplaceAll(String, Pattern, Closure)
public static CharSequence replaceAll(CharSequence self, CharSequence regex, CharSequence replacement)
self
- a CharSequenceregex
- the capturing regexreplacement
- the capturing regex
PatternSyntaxException
- if the regular expression's syntax is invalidString.replaceAll(String, String)
public static String replaceFirst(String self, String regex, Closure closure)
For example (with some replaceAll variants thrown in for comparison purposes),
assert "hellO world" == "hello world".replaceFirst("(o)") { it[0].toUpperCase() } // first match assert "hellO wOrld" == "hello world".replaceAll("(o)") { it[0].toUpperCase() } // all matches assert '1-FISH, two fish' == "one fish, two fish".replaceFirst(/([a-z]{3})\s([a-z]{4})/) { [one:1, two:2][it[1]] + '-' + it[2].toUpperCase() } assert '1-FISH, 2-FISH' == "one fish, two fish".replaceAll(/([a-z]{3})\s([a-z]{4})/) { [one:1, two:2][it[1]] + '-' + it[2].toUpperCase() }
self
- a Stringregex
- the capturing regexclosure
- the closure to apply on the first captured group
PatternSyntaxException
- if the regular expression's syntax is invalidMatcher.quoteReplacement(java.lang.String)
,
replaceFirst(String, Pattern, Closure)
public static String replaceFirst(CharSequence self, CharSequence regex, CharSequence replacement)
self
- a CharSequenceregex
- the capturing regexreplacement
- the capturing regex
PatternSyntaxException
- if the regular expression's syntax is invalidString.replaceAll(String, String)
public static String replaceFirst(CharSequence self, CharSequence regex, Closure closure)
self
- a CharSequenceregex
- the capturing regexclosure
- the closure to apply on the first captured group
PatternSyntaxException
- if the regular expression's syntax is invalidreplaceFirst(String, String, Closure)
public static String replaceAll(String self, Pattern pattern, Closure closure)
For examples,
assert "hellO wOrld" == "hello world".replaceAll(~"(o)") { it[0].toUpperCase() } assert "FOOBAR-FOOBAR-" == "foobar-FooBar-".replaceAll(~"(([fF][oO]{2})[bB]ar)", { it[0].toUpperCase() }) Here, it[0] is the global string of the matched group it[1] is the first string in the matched group it[2] is the second string in the matched group assert "FOOBAR-FOOBAR-" == "foobar-FooBar-".replaceAll(~"(([fF][oO]{2})[bB]ar)", { Object[] it -> it[0].toUpperCase() }) Here, it[0] is the global string of the matched group it[1] is the first string in the matched group it[2] is the second string in the matched group assert "FOO-FOO-" == "foobar-FooBar-".replaceAll("(([fF][oO]{2})[bB]ar)", { x, y, z -> z.toUpperCase() }) Here, x is the global string of the matched group y is the first string in the matched group z is the second string in the matched group
Note that unlike String.replaceAll(String regex, String replacement), where the replacement string treats '$' and '\' specially (for group substitution), the result of the closure is converted to a string and that value is used literally for the replacement.
self
- a Stringpattern
- the capturing regex Patternclosure
- the closure to apply on each captured group
Matcher.quoteReplacement(java.lang.String)
public static String replaceAll(CharSequence self, Pattern pattern, Closure closure)
self
- a CharSequencepattern
- the capturing regex Patternclosure
- the closure to apply on each captured group
replaceAll(String, Pattern, Closure)
public static String replaceFirst(String self, Pattern pattern, Closure closure)
For example (with some replaceAll variants thrown in for comparison purposes),
assert "hellO world" == "hello world".replaceFirst(~"(o)") { it[0].toUpperCase() } // first match assert "hellO wOrld" == "hello world".replaceAll(~"(o)") { it[0].toUpperCase() } // all matches assert '1-FISH, two fish' == "one fish, two fish".replaceFirst(~/([a-z]{3})\s([a-z]{4})/) { [one:1, two:2][it[1]] + '-' + it[2].toUpperCase() } assert '1-FISH, 2-FISH' == "one fish, two fish".replaceAll(~/([a-z]{3})\s([a-z]{4})/) { [one:1, two:2][it[1]] + '-' + it[2].toUpperCase() }
self
- a Stringpattern
- the capturing regex Patternclosure
- the closure to apply on the first captured group
replaceAll(String, Pattern, Closure)
public static String replaceFirst(CharSequence self, Pattern pattern, Closure closure)
self
- a CharSequencepattern
- the capturing regex Patternclosure
- the closure to apply on the first captured group
replaceFirst(String, Pattern, Closure)
public static String padLeft(String self, Number numberOfChars, String padding)
println 'Numbers:' [1, 10, 100, 1000].each{ println it.toString().padLeft(5, '*') } [2, 20, 200, 2000].each{ println it.toString().padLeft(5, '*_') }will produce output like:
Numbers: ****1 ***10 **100 *1000 *_*_2 *_*20 *_200 *2000
self
- a String objectnumberOfChars
- the total minimum number of characters of the resulting stringpadding
- the characters used for padding
public static CharSequence padLeft(CharSequence self, Number numberOfChars, CharSequence padding)
self
- a CharSequence objectnumberOfChars
- the total minimum number of characters of the resulting CharSequencepadding
- the characters used for padding
padLeft(String, Number, String)
public static String padLeft(String self, Number numberOfChars)
println 'Numbers:' [1, 10, 100, 1000].each{ println it.toString().padLeft(5) }will produce output like:
Numbers: 1 10 100 1000
self
- a String objectnumberOfChars
- the total minimum number of characters of the resulting string
padLeft(String, Number, String)
public static CharSequence padLeft(CharSequence self, Number numberOfChars)
self
- a CharSequence objectnumberOfChars
- the total minimum number of characters of the resulting CharSequence
padLeft(CharSequence, Number, CharSequence)
public static String padRight(String self, Number numberOfChars, String padding)
['A', 'BB', 'CCC', 'DDDD'].each{ println it.padRight(5, '#') + it.size() }will produce output like:
A####1 BB###2 CCC##3 DDDD#4
self
- a String objectnumberOfChars
- the total minimum number of characters of the resulting stringpadding
- the characters used for padding
public static CharSequence padRight(CharSequence self, Number numberOfChars, CharSequence padding)
self
- a CharSequence objectnumberOfChars
- the total minimum number of characters of the resulting CharSequencepadding
- the characters used for padding
padRight(String, Number, String)
public static String padRight(String self, Number numberOfChars)
['A', 'BB', 'CCC', 'DDDD'].each{ println it.padRight(5) + it.size() }will produce output like:
A 1 BB 2 CCC 3 DDDD 4
self
- a String objectnumberOfChars
- the total minimum number of characters of the resulting string
public static CharSequence padRight(CharSequence self, Number numberOfChars)
self
- a CharSequence objectnumberOfChars
- the total minimum number of characters of the resulting string
padRight(String, Number)
public static String center(String self, Number numberOfChars, String padding)
['A', 'BB', 'CCC', 'DDDD'].each{ println '|' + it.center(6, '+') + '|' }will produce output like:
|++A+++| |++BB++| |+CCC++| |+DDDD+|
self
- a String objectnumberOfChars
- the total minimum number of characters of the resulting stringpadding
- the characters used for padding
public static CharSequence center(CharSequence self, Number numberOfChars, CharSequence padding)
self
- a CharSequence objectnumberOfChars
- the total minimum number of characters of the resulting CharSequencepadding
- the characters used for padding
center(String, Number, String)
public static String center(String self, Number numberOfChars)
['A', 'BB', 'CCC', 'DDDD'].each{ println '|' + it.center(6) + '|' }will produce output like:
| A | | BB | | CCC | | DDDD |
self
- a String objectnumberOfChars
- the total minimum number of characters of the resulting string
center(String, Number, String)
public static CharSequence center(CharSequence self, Number numberOfChars)
self
- a CharSequence objectnumberOfChars
- the total minimum number of characters of the resulting CharSequence
center(String, Number)
public static Object getAt(Matcher matcher, int idx)
def p = /ab[d|f]/ def m = "abcabdabeabf" =~ p assert 2 == m.count assert 2 == m.size() // synonym for m.getCount() assert ! m.hasGroup() assert 0 == m.groupCount() def matches = ["abd", "abf"] for (i in 0..<m.count) { assert m[i] == matches[i] }For an example using group matches,
def p = /(?:ab([c|d|e|f]))/ def m = "abcabdabeabf" =~ p assert 4 == m.count assert m.hasGroup() assert 1 == m.groupCount() def matches = [["abc", "c"], ["abd", "d"], ["abe", "e"], ["abf", "f"]] for (i in 0..<m.count) { assert m[i] == matches[i] }For another example using group matches,
def m = "abcabdabeabfabxyzabx" =~ /(?:ab([d|x-z]+))/ assert 3 == m.count assert m.hasGroup() assert 1 == m.groupCount() def matches = [["abd", "d"], ["abxyz", "xyz"], ["abx", "x"]] for (i in 0..<m.count) { assert m[i] == matches[i] }
matcher
- a Matcheridx
- an index
public static void setIndex(Matcher matcher, int idx)
matcher
- a Matcheridx
- the index numberpublic static int getCount(Matcher matcher)
matcher
- a Matcher
public static boolean hasGroup(Matcher matcher)
matcher
- a Matcher
true
if matcher contains at least one group.public static <T> List<T> getAt(List<T> self, Range range)
def list = [1, "a", 4.5, true] assert list[1..2] == ["a", 4.5]
self
- a Listrange
- a Range indicating the items to get
List.subList(int,int)
public static <T> List<T> getAt(List<T> self, EmptyRange range)
def list = [true, 1, 3.4] assert list[0..<0] == []
self
- a Listrange
- a Range indicating the items to get
List.subList(int,int)
public static <T> List<T> getAt(List<T> self, Collection indices)
def list = [true, 1, 3.4, false] assert list[1,0,2] == [1, true, 3.4]
self
- a Listindices
- a Collection of indices
public static <T> List<T> getAt(T[] self, Collection indices)
self
- an Array of Objectsindices
- a Collection of indices
public static CharSequence getAt(CharSequence self, Collection indices)
self
- a CharSequenceindices
- a Collection of indices
public static String getAt(String self, Collection indices)
self
- a Stringindices
- a Collection of indices
public static List getAt(Matcher self, Collection indices)
self
- a Matcherindices
- a Collection of indices
public static <K,V> Map<K,V> subMap(Map<K,V> map, Collection<K> keys)
assert [1:10, 2:20, 4:40].subMap( [2, 4] ) == [2:20, 4:40]
map
- a Mapkeys
- a Collection of keys
public static <K,V> V get(Map<K,V> map, K key, V defaultValue)
def map=[:] map.get("a", []) << 5 assert map == [a:[5]]
map
- a Mapkey
- the key to lookup the value ofdefaultValue
- the value to return and add to the map for this key if
there is no entry for the given key
public static <T> List<T> getAt(T[] array, Range range)
array
- an Array of Objectsrange
- a Range
public static <T> List<T> takeWhile(List<T> self, Closure condition)
takeWhile(Iterable, groovy.lang.Closure)
except that it attempts to preserve the type of the original list.
def nums = [ 1, 3, 2 ] assert nums.takeWhile{ it < 1 } == [] assert nums.takeWhile{ it < 3 } == [ 1 ] assert nums.takeWhile{ it < 4 } == [ 1, 3, 2 ]
self
- the original listcondition
- the closure that must evaluate to true to
continue taking elements
public static <T> List<T> takeWhile(Iterable<T> self, Closure condition)
class AbcIterable implements Iterable{ Iterator iterator() { "abc".iterator() } } def abc = new AbcIterable() assert abc.takeWhile{ it < 'b' } == ['a'] assert abc.takeWhile{ it <= 'b' } == ['a', 'b']
self
- an Iterablecondition
- the closure that must evaluate to true to
continue taking elements
public static <K,V> Map<K,V> takeWhile(Map<K,V> self, Closure<?> condition)
def shopping = [milk:1, bread:2, chocolate:3] assert shopping.takeWhile{ it.key.size() < 6 } == [milk:1, bread:2] assert shopping.takeWhile{ it.value % 2 } == [milk:1] assert shopping.takeWhile{ k, v -> k.size() + v <= 7 } == [milk:1, bread:2]If the map instance does not have ordered keys, then this function could appear to take random entries. Groovy by default uses LinkedHashMap, so this shouldn't be an issue in the main.
self
- a Mapcondition
- a 1 (or 2) arg Closure that must evaluate to true for the
entry (or key and value) to continue taking elements
public static <T> T[] takeWhile(T[] self, Closure condition)
def nums = [ 1, 3, 2 ] as Integer[] assert nums.takeWhile{ it < 1 } == [] as Integer[] assert nums.takeWhile{ it < 3 } == [ 1 ] as Integer[] assert nums.takeWhile{ it < 4 } == [ 1, 3, 2 ] as Integer[]
self
- the original arraycondition
- the closure that must evaluate to true to
continue taking elements
public static <T> Iterator<T> takeWhile(Iterator<T> self, Closure condition)
def a = 0 def iter = [ hasNext:{ true }, next:{ a++ } ] as Iterator assert [].iterator().takeWhile{ it < 3 }.toList() == [] assert [1, 2, 3, 4, 5].iterator().takeWhile{ it < 3 }.toList() == [ 1, 2 ] assert iter.takeWhile{ it < 5 }.toList() == [ 0, 1, 2, 3, 4 ]
self
- the Iteratorcondition
- the closure that must evaluate to true to
continue taking elements
public static CharSequence takeWhile(CharSequence self, Closure closure)
def text = "Groovy" assert text.takeWhile{ it < 'A' } == '' assert text.takeWhile{ it < 'Z' } == 'G' assert text.takeWhile{ it < 'z' } == 'Groovy'
self
- the original CharSequencenum
- the number of chars to take from this CharSequence
num
chars,
or else the whole CharSequence if it has less then num
elements.public static <T> List<T> getAt(T[] array, IntRange range)
array
- an Array of Objectsrange
- an IntRange
public static <T> List<T> getAt(T[] array, EmptyRange range)
array
- an Array of Objectsrange
- an EmptyRange
public static <T> List<T> getAt(T[] array, ObjectRange range)
array
- an Array of Objectsrange
- an ObjectRange
public static <T> List<T> toList(T[] array)
array
- an Array of Objects
public static <T> T getAt(List<T> self, int idx)
def list = [2, "a", 5.3] assert list[1] == "a"
self
- a Listidx
- an index
public static <T> T getAt(Iterator<T> self, int idx)
def iter = [2, "a", 5.3].iterator() assert iter[1] == "a"A more elaborate example:
def items = [2, "a", 5.3] def iter = items.iterator() assert iter[-1] == 5.3 // iter exhausted, so reset iter = items.iterator() assert iter[1] == "a" // iter partially exhausted so now idx starts after "a" assert iter[0] == 5.3
self
- an Iteratoridx
- an index value (-self.size() <= idx < self.size())
public static <T> void putAt(List<T> self, int idx, T value)
def list = [2, 3] list[0] = 1 assert list == [1, 3]
self
- a Listidx
- an indexvalue
- the value to put at the given indexpublic static void putAt(StringBuffer self, IntRange range, Object value)
self
- a StringBufferrange
- a Rangevalue
- the object that's toString() will be insertedpublic static void putAt(StringBuffer self, EmptyRange range, Object value)
self
- a StringBufferrange
- a Rangevalue
- the object that's toString() will be insertedpublic static void putAt(List self, EmptyRange range, Object value)
def list = ["a", true] list[1..<1] = 5 assert list == ["a", 5, true]
self
- a Listrange
- the (in this case empty) subset of the list to setvalue
- the values to put at the given sublist or a Collection of valuespublic static void putAt(List self, EmptyRange range, Collection value)
def list = ["a", true] list[1..<1] = [4, 3, 2] assert list == ["a", 4, 3, 2, true]
self
- a Listrange
- the (in this case empty) subset of the list to setvalue
- the Collection of valuesputAt(java.util.List, groovy.lang.EmptyRange, java.lang.Object)
public static void putAt(List self, IntRange range, Collection col)
def myList = [4, 3, 5, 1, 2, 8, 10] myList[3..5] = ["a", true] assert myList == [4, 3, 5, "a", true, 10]Items in the given range are replaced with items from the collection.
self
- a Listrange
- the subset of the list to setcol
- the collection of values to put at the given sublistpublic static void putAt(List self, IntRange range, Object value)
def myList = [4, 3, 5, 1, 2, 8, 10] myList[3..5] = "b" assert myList == [4, 3, 5, "b", 10]Items in the given range are replaced with the operand. The
value
operand is
always treated as a single value.
self
- a Listrange
- the subset of the list to setvalue
- the value to put at the given sublistpublic static void putAt(List self, List splice, List values)
def list = ["a", true, 42, 9.4] list[1, 4] = ["x", false] assert list == ["a", "x", 42, 9.4, false]
self
- a Listsplice
- the subset of the list to setvalues
- the value to put at the given sublistpublic static void putAt(List self, List splice, Object value)
def list = ["a", true, 42, 9.4] list[1, 3] = 5 assert list == ["a", 5, 42, 5]
self
- a Listsplice
- the subset of the list to setvalue
- the value to put at the given sublistprotected static List getSubList(List self, List splice)
public static <K,V> V getAt(Map<K,V> self, K key)
def map = [a:10] assert map["a"] == 10
self
- a Mapkey
- an Object as a key for the map
public static <K,V> Map<K,V> plus(Map<K,V> left, Map<K,V> right)
Map
containing all entries from left
and right
,
giving precedence to right
. Any keys appearing in both Maps
will appear in the resultant map with values from the right
operand. If the left
map is one of TreeMap, LinkedHashMap, Hashtable
or Properties, the returned Map will preserve that type, otherwise a HashMap will
be returned.
Roughly equivalent to Map m = new HashMap(); m.putAll(left); m.putAll(right); return m;
but with some additional logic to preserve the left
Map type for common cases as
described above.
assert [a:10, b:20] + [a:5, c:7] == [a:5, b:20, c:7]
left
- a Mapright
- a Map
public static <K,V> V putAt(Map<K,V> self, K key, V value)
self
- a Mapkey
- an Object as a key for the mapvalue
- the value to put into the map
public static List getAt(Collection coll, String property)
assert [String, Long, Integer] == ["a",5L,2]["class"]
coll
- a Collectionproperty
- a String
public static <K,V> Map<K,V> asImmutable(Map<? extends K,? extends V> self)
self
- a Map
Collections.unmodifiableMap(java.util.Map)
public static <K,V> SortedMap<K,V> asImmutable(SortedMap<K,? extends V> self)
self
- a SortedMap
Collections.unmodifiableSortedMap(java.util.SortedMap)
public static <T> List<T> asImmutable(List<? extends T> self)
self
- a List
Collections.unmodifiableList(java.util.List)
public static <T> Set<T> asImmutable(Set<? extends T> self)
self
- a Set
Collections.unmodifiableSet(java.util.Set)
public static <T> SortedSet<T> asImmutable(SortedSet<T> self)
self
- a SortedSet
Collections.unmodifiableSortedSet(java.util.SortedSet)
public static <T> Collection<T> asImmutable(Collection<? extends T> self)
def mutable = [1,2,3] def immutable = mutable.asImmutable() mutable << 4 try { immutable << 4 assert false } catch (UnsupportedOperationException) { assert true }
self
- a Collection
Collections.unmodifiableCollection(java.util.Collection)
public static <K,V> Map<K,V> asSynchronized(Map<K,V> self)
self
- a Map
Collections.synchronizedMap(java.util.Map)
public static <K,V> SortedMap<K,V> asSynchronized(SortedMap<K,V> self)
self
- a SortedMap
Collections.synchronizedSortedMap(java.util.SortedMap)
public static <T> Collection<T> asSynchronized(Collection<T> self)
self
- a Collection
Collections.synchronizedCollection(java.util.Collection)
public static <T> List<T> asSynchronized(List<T> self)
self
- a List
Collections.synchronizedList(java.util.List)
public static <T> Set<T> asSynchronized(Set<T> self)
self
- a Set
Collections.synchronizedSet(java.util.Set)
public static <T> SortedSet<T> asSynchronized(SortedSet<T> self)
self
- a SortedSet
Collections.synchronizedSortedSet(java.util.SortedSet)
public static <T> T[] plus(T[] left, T[] right)
Integer[] a = [1, 2, 3] Integer[] b = [4, 5, 6] assert a + b == [1, 2, 3, 4, 5, 6] as Integer[]
left
- the left Arrayright
- the right Array
public static <T> T[] plus(T[] left, T right)
Integer[] a = [1, 2, 3] Integer[] result = a + 4 assert result == [1, 2, 3, 4] as Integer[]
left
- the arrayright
- the value to append
public static <T> T[] plus(T[] left, Collection<T> right)
Integer[] a = [1, 2, 3] def additions = [7, 8] assert a + additions == [1, 2, 3, 7, 8] as Integer[]
left
- the arrayright
- a Collection to be appended
public static <T> T[] plus(T[] left, Iterable<T> right)
class AbcIterable implements Iterable{ Iterator iterator() { "abc".iterator() } } String[] letters = ['x', 'y', 'z'] def result = letters + new AbcIterable() assert result == ['x', 'y', 'z', 'a', 'b', 'c'] as String[] assert result.class.array
left
- the arrayright
- an Iterable to be appended
public static <T> Collection<T> plus(Collection<T> left, Collection<T> right)
assert [1,2,3,4] == [1,2] + [3,4]
left
- the left Collectionright
- the right Collection
public static <T> Collection<T> plus(Collection<T> left, Iterable<T> right)
left
- the left Collectionright
- the right Iterable
plus(Collection, Collection)
public static <T> List<T> plus(List<T> self, int index, T[] items)
def items = [1, 2, 3] def newItems = items.plus(2, 'a'..'c' as String[]) assert newItems == [1, 2, 'a', 'b', 'c', 3] assert items == [1, 2, 3]See also
addAll
for similar functionality with modify semantics, i.e. which performs
the changes on the original list itself.
self
- an original listitems
- array containing elements to be merged with elements from the original listindex
- index at which to insert the first element from the specified array
plus(List, int, List)
public static <T> List<T> plus(List<T> self, int index, List<T> additions)
def items = [1, 2, 3] def newItems = items.plus(2, 'a'..'c') assert newItems == [1, 2, 'a', 'b', 'c', 3] assert items == [1, 2, 3]See also
addAll
for similar functionality with modify semantics, i.e. which performs
the changes on the original list itself.
self
- an original Listadditions
- a List containing elements to be merged with elements from the original Listindex
- index at which to insert the first element from the given additions List
public static <T> List<T> plus(List<T> self, int index, Iterable<T> additions)
self
- an original listadditions
- an Iterable containing elements to be merged with the elements from the original Listindex
- index at which to insert the first element from the given additions Iterable
plus(List, int, List)
public static <T> Collection<T> plus(Collection<T> left, T right)
assert [1,2,3] == [1,2] + 3
left
- a Collectionright
- an object to add/append
public static SpreadMap spread(Map self)
toSpreadMap(java.util.Map)
.
self
- a map
public static SpreadMap toSpreadMap(Map self)
SpreadMap
from this map.
The example below shows the various possible use cases:
def fn(Map m) { return m.a + m.b + m.c + m.d } assert fn(a:1, b:2, c:3, d:4) == 10 assert fn(a:1, *:[b:2, c:3], d:4) == 10 assert fn([a:1, b:2, c:3, d:4].toSpreadMap()) == 10 assert fn((['a', 1, 'b', 2, 'c', 3, 'd', 4] as Object[]).toSpreadMap()) == 10 assert fn(['a', 1, 'b', 2, 'c', 3, 'd', 4].toSpreadMap()) == 10 assert fn(['abcd'.toList(), 1..4].transpose().flatten().toSpreadMap()) == 10Note that toSpreadMap() is not normally used explicitly but under the covers by Groovy.
self
- a map to be converted into a SpreadMap
SpreadMap.SpreadMap(java.util.Map)
public static SpreadMap toSpreadMap(Object[] self)
self
- an object array
SpreadMap.SpreadMap(java.lang.Object[])
,
toSpreadMap(java.util.Map)
public static SpreadMap toSpreadMap(List self)
self
- a list
SpreadMap.SpreadMap(java.util.List)
,
toSpreadMap(java.util.Map)
public static <K,V> Map<K,V> withDefault(Map<K,V> self, Closure init)
get(key)
. If an unknown key is found, a default value will be
stored into the Map before being returned. The default value stored will be the
result of calling the supplied Closure with the key as the parameter to the Closure.
Example usage:
def map = [a:1, b:2].withDefault{ k -> k.toCharacter().isLowerCase() ? 10 : -10 } def expected = [a:1, b:2, c:10, D:-10] assert expected.every{ e -> e.value == map[e.key] } def constMap = [:].withDefault{ 42 } assert constMap.foo == 42 assert constMap.size() == 1
self
- a Mapinit
- a Closure which is passed the unknown key
public static <T> List<T> withDefault(List<T> self, Closure init)
withLazyDefault
which decorates a list allowing
it to grow when called with index values outside the normal list bounds.
self
- a Listinit
- a Closure with the target index as parameter which generates the default value
withLazyDefault(java.util.List, groovy.lang.Closure)
,
withEagerDefault(java.util.List, groovy.lang.Closure)
public static <T> List<T> withLazyDefault(List<T> self, Closure init)
init
Closure. Subsequent
retrieval operations if finding a null value in the list assume it was set
as null from an earlier growing operation and again call the init
Closure
to populate the retrieved value; consequently the list can't be used to store null values.
How it works: The decorated list intercepts all calls
to getAt(index)
and get(index)
. If an index greater than
or equal to the current size()
is used, the list will grow automatically
up to the specified index. Gaps will be filled by null
. If a default value
should also be used to fill gaps instead of null
, use withEagerDefault
.
If getAt(index)
or get(index)
are called and a null value
is found, it is assumed that the null value was a consequence of an earlier grow list
operation and the init
Closure is called to populate the value.
Example usage:
def list = [0, 1].withLazyDefault{ 42 } assert list[0] == 0 assert list[1] == 1 assert list[3] == 42 // default value assert list == [0, 1, null, 42] // gap filled with null // illustrate using the index when generating default values def list2 = [5].withLazyDefault{ index -> index * index } assert list2[3] == 9 assert list2 == [5, null, null, 9] assert list2[2] == 4 assert list2 == [5, null, 4, 9] // illustrate what happens with null values list2[2] = null assert list2[2] == 4
self
- a Listinit
- a Closure with the target index as parameter which generates the default value
public static <T> List<T> withEagerDefault(List<T> self, Closure init)
init
Closure. Null values
can be stored in the list.
How it works: The decorated list intercepts all calls
to getAt(index)
and get(index)
. If an index greater than
or equal to the current size()
is used, the list will grow automatically
up to the specified index. Gaps will be filled by calling the init
Closure.
If generating a default value is a costly operation consider using withLazyDefault
.
Example usage:
def list = [0, 1].withEagerDefault{ 42 } assert list[0] == 0 assert list[1] == 1 assert list[3] == 42 // default value assert list == [0, 1, 42, 42] // gap filled with default value // illustrate using the index when generating default values def list2 = [5].withEagerDefault{ index -> index * index } assert list2[3] == 9 assert list2 == [5, 1, 4, 9] // illustrate what happens with null values list2[2] = null assert list2[2] == null assert list2 == [5, 1, null, 9]
self
- a Listinit
- a Closure with the target index as parameter which generates the default value
public static <T> List<T> sort(Collection<T> self)
assert [1,2,3] == [3,1,2].sort()
self
- the collection to be sorted
sort(Collection, boolean)
public static <T> List<T> sort(Collection<T> self, boolean mutate)
assert [1,2,3] == [3,1,2].sort()
def orig = [1, 3, 2] def sorted = orig.sort(false) assert orig == [1, 3, 2] assert sorted == [1, 2, 3]
self
- the collection to be sortedmutate
- false will always cause a new list to be created, true will mutate lists in place
public static <K,V> Map<K,V> sort(Map<K,V> self, Closure closure)
def map = [a:5, b:3, c:6, d:4].sort { a, b -> a.value <=> b.value } assert map == [b:3, d:4, a:5, c:6]
self
- the original unsorted mapclosure
- a Closure used as a comparator
public static <K,V> Map<K,V> sort(Map<K,V> self, Comparator<K> comparator)
def map = [ba:3, cz:6, ab:5].sort({ a, b -> a[-1] <=> b[-1] } as Comparator) assert map*.value == [3, 5, 6]
self
- the original unsorted mapcomparator
- a Comparator
public static <K,V> Map<K,V> sort(Map<K,V> self)
map = [ba:3, cz:6, ab:5].sort() assert map*.value == [5, 3, 6]
self
- the original unsorted map
public static <T> T[] sort(T[] self)
self
- the array to be sorted
public static <T> T[] sort(T[] self, boolean mutate)
def orig = ["hello","hi","Hey"] as String[] def sorted = orig.sort(false) assert orig == ["hello","hi","Hey"] as String[] assert sorted == ["Hey","hello","hi"] as String[] orig.sort(true) assert orig == ["Hey","hello","hi"] as String[]
self
- the array to be sortedmutate
- false will always cause a new array to be created, true will mutate the array in place
public static <T> Iterator<T> sort(Iterator<T> self)
self
- the Iterator to be sorted
public static <T> Iterator<T> sort(Iterator<T> self, Comparator<T> comparator)
self
- the Iterator to be sortedcomparator
- a Comparator used for comparing items
public static <T> List<T> sort(Collection<T> self, Comparator<T> comparator)
assert ["hi","hey","hello"] == ["hello","hi","hey"].sort( { a, b -> a.length() <=> b.length() } as Comparator )
assert ["hello","Hey","hi"] == ["hello","hi","Hey"].sort(String.CASE_INSENSITIVE_ORDER)
self
- a collection to be sortedcomparator
- a Comparator used for the comparison
sort(Collection, boolean, Comparator)
public static <T> List<T> sort(Collection<T> self, boolean mutate, Comparator<T> comparator)
assert ["hi","hey","hello"] == ["hello","hi","hey"].sort( { a, b -> a.length() <=> b.length() } as Comparator )
def orig = ["hello","hi","Hey"] def sorted = orig.sort(false, String.CASE_INSENSITIVE_ORDER) assert orig == ["hello","hi","Hey"] assert sorted == ["hello","Hey","hi"]
self
- a collection to be sortedmutate
- false will always cause a new list to be created, true will mutate lists in placecomparator
- a Comparator used for the comparison
public static <T> T[] sort(T[] self, Comparator<T> comparator)
self
- the array to be sortedcomparator
- a Comparator used for the comparison
public static <T> T[] sort(T[] self, boolean mutate, Comparator<T> comparator)
def orig = ["hello","hi","Hey"] as String[] def sorted = orig.sort(false, String.CASE_INSENSITIVE_ORDER) assert orig == ["hello","hi","Hey"] as String[] assert sorted == ["hello","Hey","hi"] as String[] orig.sort(true, String.CASE_INSENSITIVE_ORDER) assert orig == ["hello","Hey","hi"] as String[]
self
- the array containing elements to be sortedmutate
- false will always cause a new array to be created, true will mutate arrays in placecomparator
- a Comparator used for the comparison
public static <T> Iterator<T> sort(Iterator<T> self, Closure closure)
self
- the Iterator to be sortedclosure
- a Closure used to determine the correct ordering
public static <T> T[] sort(T[] self, Closure closure)
self
- the array containing the elements to be sortedclosure
- a Closure used to determine the correct ordering
public static <T> T[] sort(T[] self, boolean mutate, Closure closure)
def orig = ["hello","hi","Hey"] as String[] def sorted = orig.sort(false) { it.size() } assert orig == ["hello","hi","Hey"] as String[] assert sorted == ["hi","Hey","hello"] as String[] orig.sort(true) { it.size() } assert orig == ["hi","Hey","hello"] as String[]
self
- the array to be sortedmutate
- false will always cause a new array to be created, true will mutate arrays in placeclosure
- a Closure used to determine the correct ordering
public static <T> List<T> sort(Collection<T> self, Closure closure)
assert ["hi","hey","hello"] == ["hello","hi","hey"].sort { it.length() }
assert ["hi","hey","hello"] == ["hello","hi","hey"].sort { a, b -> a.length() <=> b.length() }
self
- a Collection to be sortedclosure
- a 1 or 2 arg Closure used to determine the correct ordering
sort(Collection, boolean, Closure)
public static <T> List<T> sort(Collection<T> self, boolean mutate, Closure closure)
assert ["hi","hey","hello"] == ["hello","hi","hey"].sort { it.length() }
assert ["hi","hey","hello"] == ["hello","hi","hey"].sort { a, b -> a.length() <=> b.length() }
def orig = ["hello","hi","Hey"] def sorted = orig.sort(false) { it.toUpperCase() } assert orig == ["hello","hi","Hey"] assert sorted == ["hello","Hey","hi"]
self
- a Collection to be sortedmutate
- false will always cause a new list to be created, true will mutate lists in placeclosure
- a 1 or 2 arg Closure used to determine the correct ordering
public static <T> SortedSet<T> sort(SortedSet<T> self)
self
- an already sorted set
public static <K,V> SortedMap<K,V> sort(SortedMap<K,V> self)
self
- an already sorted map
public static <T> T pop(List<T> self)
def list = ["a", false, 2] assert list.pop() == 2 assert list == ["a", false]
self
- a List
NoSuchElementException
- if the list is empty and you try to pop() it.public static <K,V> Map<K,V> putAll(Map<K,V> self, Collection<Map.Entry<K,V>> entries)
self
- a Mapentries
- a Collection of Map.Entry items to be added to the Map.
public static <K,V> Map<K,V> plus(Map<K,V> self, Collection<Map.Entry<K,V>> entries)
Map
containing all entries from self
and entries
,
giving precedence to entries
. Any keys appearing in both Maps
will appear in the resultant map with values from the entries
operand. If self
map is one of TreeMap, LinkedHashMap, Hashtable
or Properties, the returned Map will preserve that type, otherwise a HashMap will
be returned.
self
- a Mapentries
- a Collection of Map.Entry items to be added to the Map.
public static <T> boolean push(List<T> self, T value)
def list = [3, 4, 2] list.push("x") assert list == [3, 4, 2, "x"]
self
- a Listvalue
- element to be appended to this list.
NoSuchElementException
- if the list is empty and you try to pop() it.public static <T> T last(List<T> self)
def list = [3, 4, 2] assert list.last() == 2 // check original is unaltered assert list == [3, 4, 2]
self
- a List
NoSuchElementException
- if the list is empty and you try to access the last() item.public static <T> T last(Iterable<T> self)
def set = [3, 4, 2] as LinkedHashSet assert set.last() == 2 // check original unaltered assert set == [3, 4, 2] as SetThe first element returned by the Iterable's iterator is returned. If the Iterable doesn't guarantee a defined order it may appear like a random element is returned.
self
- an Iterable
NoSuchElementException
- if the Iterable is empty and you try to access the last() item.public static <T> T last(T[] self)
def array = [3, 4, 2].toArray() assert array.last() == 2
self
- an array
NoSuchElementException
- if the array is empty and you try to access the last() item.public static <T> T first(List<T> self)
def list = [3, 4, 2] assert list.first() == 3 // check original is unaltered assert list == [3, 4, 2]
self
- a List
NoSuchElementException
- if the list is empty and you try to access the first() item.public static <T> T first(Iterable<T> self)
def set = [3, 4, 2] as LinkedHashSet assert set.first() == 3 // check original is unaltered assert set == [3, 4, 2] as SetThe first element returned by the Iterable's iterator is returned. If the Iterable doesn't guarantee a defined order it may appear like a random element is returned.
self
- an Iterable
NoSuchElementException
- if the Iterable is empty and you try to access the first() item.public static <T> T first(T[] self)
def array = [3, 4, 2].toArray() assert array.first() == 3
self
- an array
NoSuchElementException
- if the array is empty and you try to access the first() item.public static <T> T head(List<T> self)
def list = [3, 4, 2] assert list.head() == 3 assert list == [3, 4, 2]
self
- a List
NoSuchElementException
- if the list is empty and you try to access the head() item.public static <T> T head(T[] self)
def array = [3, 4, 2].toArray() assert array.head() == 3
self
- an Object array
NoSuchElementException
- if the array is empty and you try to access the head() item.public static <T> List<T> tail(List<T> self)
def list = [3, 4, 2] assert list.tail() == [4, 2] assert list == [3, 4, 2]
self
- a List
NoSuchElementException
- if the list is empty and you try to access the tail() item.public static <T> T[] tail(T[] self)
String[] strings = ["a", "b", "c"] def result = strings.tail() assert strings.class.componentType == String
self
- an Object array
NoSuchElementException
- if the list is empty and you try to access the tail() item.public static <T> List<T> take(List<T> self, int num)
num
elements from the head of this list.
def strings = [ 'a', 'b', 'c' ] assert strings.take( 0 ) == [] assert strings.take( 2 ) == [ 'a', 'b' ] assert strings.take( 5 ) == [ 'a', 'b', 'c' ]Similar to
take(Iterable, int)
except that it attempts to preserve the type of the original list.
self
- the original listnum
- the number of elements to take from this list
num
elements of this list,
or else the whole list if it has less then num
elements.public static <T> T[] take(T[] self, int num)
num
elements from the head of this array.
String[] strings = [ 'a', 'b', 'c' ] assert strings.take( 0 ) == [] as String[] assert strings.take( 2 ) == [ 'a', 'b' ] as String[] assert strings.take( 5 ) == [ 'a', 'b', 'c' ] as String[]
self
- the original arraynum
- the number of elements to take from this array
num
elements of this array,
or else the whole array if it has less then num
elements.public static <T> List<T> take(Iterable<T> self, int num)
num
elements from the head of this Iterable.
class AbcIterable implements Iterable{ Iterator iterator() { "abc".iterator() } } def abc = new AbcIterable() assert abc.take(0) == [] assert abc.take(1) == ['a'] assert abc.take(3) == ['a', 'b', 'c'] assert abc.take(5) == ['a', 'b', 'c']
self
- the original Iterablenum
- the number of elements to take from this Iterable
num
elements from this Iterable,
or else all the elements from the Iterable if it has less then num
elements.public static <K,V> Map<K,V> take(Map<K,V> self, int num)
num
elements from the head of this map.
If the map instance does not have ordered keys, then this function could return a random num
entries. Groovy by default uses LinkedHashMap, so this shouldn't be an issue in the main.
def strings = [ 'a':10, 'b':20, 'c':30 ] assert strings.take( 0 ) == [:] assert strings.take( 2 ) == [ 'a':10, 'b':20 ] assert strings.take( 5 ) == [ 'a':10, 'b':20, 'c':30 ]
self
- the original mapnum
- the number of elements to take from this map
num
elements of this map,
or else the whole map if it has less then num
elements.public static <T> Iterator<T> take(Iterator<T> self, int num)
num
elements from this iterator.
The original iterator is stepped along by num
elements.
def a = 0 def iter = [ hasNext:{ true }, next:{ a++ } ] as Iterator def iteratorCompare( Iterator a, List b ) { a.collect { it } == b } assert iteratorCompare( iter.take( 0 ), [] ) assert iteratorCompare( iter.take( 2 ), [ 0, 1 ] ) assert iteratorCompare( iter.take( 5 ), [ 2, 3, 4, 5, 6 ] )
self
- the Iteratornum
- the number of elements to take from this iterator
num
elements of this iterator.public static CharSequence take(CharSequence self, int num)
num
elements from this CharSequence.
def text = "Groovy" assert text.take( 0 ) == '' assert text.take( 2 ) == 'Gr' assert text.take( 7 ) == 'Groovy'
self
- the original CharSequencenum
- the number of chars to take from this CharSequence
num
chars,
or else the whole CharSequence if it has less then num
elements.public static <T> List<T> drop(List<T> self, int num)
def strings = [ 'a', 'b', 'c' ] assert strings.drop( 0 ) == [ 'a', 'b', 'c' ] assert strings.drop( 2 ) == [ 'c' ] assert strings.drop( 5 ) == []Similar to
drop(Iterable, int)
except that it attempts to preserve the type of the original list.
self
- the original listnum
- the number of elements to drop from this list
num
ones, or else the empty list, if this list has
less than num
elements.public static <T> List<T> drop(Iterable<T> self, int num)
class AbcIterable implements Iterable{ Iterator iterator() { "abc".iterator() } } def abc = new AbcIterable() assert abc.drop(0) == ['a', 'b', 'c'] assert abc.drop(1) == ['b', 'c'] assert abc.drop(3) == [] assert abc.drop(5) == []
self
- the original Iterablenum
- the number of elements to drop from this Iterable
num
elements,
or an empty list if it has less then num
elements.public static <T> T[] drop(T[] self, int num)
String[] strings = [ 'a', 'b', 'c' ] assert strings.drop( 0 ) == [ 'a', 'b', 'c' ] as String[] assert strings.drop( 2 ) == [ 'c' ] as String[] assert strings.drop( 5 ) == [] as String[]
self
- the original arraynum
- the number of elements to drop from this array
num
ones, or else the empty array, if this
array has less than num
elements.public static <K,V> Map<K,V> drop(Map<K,V> self, int num)
def strings = [ 'a':10, 'b':20, 'c':30 ] assert strings.drop( 0 ) == [ 'a':10, 'b':20, 'c':30 ] assert strings.drop( 2 ) == [ 'c':30 ] assert strings.drop( 5 ) == [:]If the map instance does not have ordered keys, then this function could drop a random
num
entries. Groovy by default uses LinkedHashMap, so this shouldn't be an issue in the main.
self
- the original mapnum
- the number of elements to drop from this map
num
ones, or else the empty map, if this map has
less than num
elements.public static <T> Iterator<T> drop(Iterator<T> self, int num)
num
elements.
def iteratorCompare( Iterator a, List b ) { a.collect { it } == b } def iter = [ 1, 2, 3, 4, 5 ].listIterator() assert iteratorCompare( iter.drop( 0 ), [ 1, 2, 3, 4, 5 ] ) iter = [ 1, 2, 3, 4, 5 ].listIterator() assert iteratorCompare( iter.drop( 2 ), [ 3, 4, 5 ] ) iter = [ 1, 2, 3, 4, 5 ].listIterator() assert iteratorCompare( iter.drop( 5 ), [] )
self
- the original iteratornum
- the number of elements to drop from this iterator
num
elements if they exist.public static CharSequence drop(CharSequence self, int num)
def text = "Groovy" assert text.drop( 0 ) == 'Groovy' assert text.drop( 2 ) == 'oovy' assert text.drop( 7 ) == ''
self
- the original CharSequencenum
- the number of characters to drop from this iterator
num
ones,
or else an empty String, if this CharSequence has less than num
characters.public static <T> List<T> dropWhile(List<T> self, Closure<?> condition)
dropWhile(Iterable, groovy.lang.Closure)
except that it attempts to preserve the type of the original list.
def nums = [ 1, 3, 2 ] assert nums.dropWhile{ it < 4 } == [] assert nums.dropWhile{ it < 3 } == [ 3, 2 ] assert nums.dropWhile{ it != 2 } == [ 2 ] assert nums.dropWhile{ it == 0 } == [ 1, 3, 2 ]
self
- the original listcondition
- the closure that must evaluate to true to continue dropping elements
public static <T> List<T> dropWhile(Iterable<T> self, Closure<?> condition)
class AbcIterable implements Iterable{ Iterator iterator() { "abc".iterator() } } def abc = new AbcIterable() assert abc.dropWhile{ it < 'b' } == ['b', 'c'] assert abc.dropWhile{ it <= 'b' } == ['c']
self
- an Iterablecondition
- the closure that must evaluate to true to continue dropping elements
public static <K,V> Map<K,V> dropWhile(Map<K,V> self, Closure<?> condition)
def shopping = [milk:1, bread:2, chocolate:3] assert shopping.takeWhile{ it.key.size() < 6 } == [milk:1, bread:2] assert shopping.takeWhile{ it.value % 2 } == [milk:1] assert shopping.takeWhile{ k, v -> k.size() + v <= 7 } == [milk:1, bread:2]If the map instance does not have ordered keys, then this function could appear to drop random entries. Groovy by default uses LinkedHashMap, so this shouldn't be an issue in the main.
self
- a Mapcondition
- a 1 (or 2) arg Closure that must evaluate to true for the
entry (or key and value) to continue dropping elements
public static <T> T[] dropWhile(T[] self, Closure<?> condition)
def nums = [ 1, 3, 2 ] as Integer[] assert nums.dropWhile{ it <= 3 } == [ ] as Integer[] assert nums.dropWhile{ it < 3 } == [ 3, 2 ] as Integer[] assert nums.dropWhile{ it != 2 } == [ 2 ] as Integer[] assert nums.dropWhile{ it == 0 } == [ 1, 3, 2 ] as Integer[]
self
- the original arraycondition
- the closure that must evaluate to true to
continue dropping elements
public static <T> Iterator<T> dropWhile(Iterator<T> self, Closure<?> condition)
def a = 0 def iter = [ hasNext:{ a < 10 }, next:{ a++ } ] as Iterator assert [].iterator().dropWhile{ it < 3 }.toList() == [] assert [1, 2, 3, 4, 5].iterator().dropWhile{ it < 3 }.toList() == [ 3, 4, 5 ] assert iter.dropWhile{ it < 5 }.toList() == [ 5, 6, 7, 8, 9 ]
self
- the Iteratorcondition
- the closure that must evaluate to true to continue dropping elements
public static <T> List<T> asList(Collection<T> self)
Example usage:
assert new HashSet().asList() instanceof List
self
- a collection to be converted into a List
public static boolean asBoolean(Object object)
object
- the object to coerce
public static boolean asBoolean(Boolean bool)
bool
- the Boolean
public static boolean asBoolean(Matcher matcher)
matcher
- the matcher
public static boolean asBoolean(Collection collection)
assert [1,2].asBoolean() == true
assert [].asBoolean() == false
collection
- the collection
public static boolean asBoolean(Map map)
assert [:] as Boolean == false assert [a:2] as Boolean == true
map
- the map
public static boolean asBoolean(Iterator iterator)
iterator
- the iterator
public static boolean asBoolean(Enumeration enumeration)
enumeration
- the enumeration
public static boolean asBoolean(CharSequence string)
string
- the character sequence
public static boolean asBoolean(Object[] array)
array
- the array
public static boolean asBoolean(byte[] array)
array
- an array
public static boolean asBoolean(short[] array)
array
- an array
public static boolean asBoolean(int[] array)
array
- an array
public static boolean asBoolean(long[] array)
array
- an array
public static boolean asBoolean(float[] array)
array
- an array
public static boolean asBoolean(double[] array)
array
- an array
public static boolean asBoolean(boolean[] array)
array
- an array
public static boolean asBoolean(char[] array)
array
- an array
public static boolean asBoolean(Character character)
character
- the character
public static boolean asBoolean(Number number)
number
- the number
public static <T> T asType(Collection col, Class<T> clazz)
col
- a collectionclazz
- the desired class
asType(java.lang.Object, java.lang.Class)
public static <T> T asType(Object[] ary, Class<T> clazz)
ary
- an arrayclazz
- the desired class
asType(java.lang.Object, java.lang.Class)
public static <T> T asType(Closure cl, Class<T> clazz)
cl
- the implementation of the single methodclazz
- the target type
public static <T> T asType(Map map, Class<T> clazz)
map
- this mapclazz
- the target type
public static <T> List<T> reverse(List<T> self)
def list = ["a", 4, false] assert list.reverse() == [false, 4, "a"] assert list == ["a", 4, false]
self
- a List
reverse(List, boolean)
public static <T> List<T> reverse(List<T> self, boolean mutate)
def list = ["a", 4, false] assert list.reverse(false) == [false, 4, "a"] assert list == ["a", 4, false] assert list.reverse(true) == [false, 4, "a"] assert list == [false, 4, "a"]
self
- a Listmutate
- true if the list itself should be reversed in place and returned, false if a new list should be created
public static <T> T[] reverse(T[] self)
self
- an array
reverse(Object[], boolean)
public static <T> T[] reverse(T[] self, boolean mutate)
self
- an arraymutate
- true if the array itself should be reversed in place and returned, false if a new array should be created
public static <T> Iterator<T> reverse(Iterator<T> self)
self
- an Iterator
public static <T> List<T> multiply(Collection<T> self, Number factor)
assert [1,2,3,1,2,3] == [1,2,3] * 2
self
- a Collectionfactor
- the number of times to append
public static <T> Collection<T> intersect(Collection<T> left, Collection<T> right)
assert [4,5] == [1,2,3,4,5].intersect([4,5,6,7,8])
left
- a Collectionright
- a Collection
public static <K,V> Map<K,V> intersect(Map<K,V> left, Map<K,V> right)
assert [4:4,5:5] == [1:1,2:2,3:3,4:4,5:5].intersect([4:4,5:5,6:6,7:7,8:8])
assert [1: 1, 2: 2, 3: 3, 4: 4].intersect( [1: 1.0, 2: 2, 5: 5] ) == [1:1, 2:2]
left
- a mapright
- a map
public static boolean disjoint(Collection left, Collection right)
true
if the intersection of two collections is empty.
assert [1,2,3].disjoint([3,4,5]) == false
assert [1,2].disjoint([3,4]) == true
left
- a Collectionright
- a Collection
true
if the intersection of two collections
is empty, false
otherwise.public static boolean equals(int[] left, int[] right)
left
- an int arrayright
- the array being compared
public static boolean equals(Object[] left, List right)
false
if either collection is null
.
left
- an arrayright
- the List being compared
public static boolean equals(List left, Object[] right)
false
if either collection is null
.
assert [1, "a"].equals( [ 1, "a" ] as Object[] )
left
- a Listright
- the Object[] being compared to
public static boolean equals(List left, List right)
null
, the result
is true; otherwise if either list is null
, the result
is false
.
assert ["a", 2].equals(["a", 2]) assert ![2, "a"].equals("a", 2) assert [2.0, "a"].equals(2L, "a") // number comparison at work
left
- a Listright
- the List being compared to
true
if the contents of both lists are identical,
false
otherwise.public static <T> boolean equals(Set<T> self, Set<T> other)
null
, the result
is true; otherwise if either set is null
, the result
is false
. Example usage:
Set s1 = ["a", 2] def s2 = [2, 'a'] as Set Set s3 = [3, 'a'] def s4 = [2.0, 'a'] as Set def s5 = [2L, 'a'] as Set assert s1.equals(s2) assert !s1.equals(s3) assert s1.equals(s4) assert s1.equals(s5)
self
- a Setother
- the Set being compared to
public static boolean equals(Map self, Map other)
Example usage:
assert [a:2, b:3] == [a:2L, b:3.0]
self
- this Mapother
- the Map being compared to
public static <T> Set<T> minus(Set<T> self, Collection<?> removeMe)
self
- a Set objectremoveMe
- the items to remove from the Set
public static <T> Set<T> minus(Set<T> self, Iterable<?> removeMe)
self
- a Set objectremoveMe
- the items to remove from the Set
public static <T> Set<T> minus(Set<T> self, Object removeMe)
self
- a Set objectremoveMe
- the element to remove from the Set
public static <T> T[] minus(T[] self, Iterable removeMe)
self
- an object arrayremoveMe
- a Collection of elements to remove
public static <T> T[] minus(T[] self, Object[] removeMe)
self
- an object arrayremoveMe
- an array of elements to remove
public static <T> List<T> minus(List<T> self, Collection<?> removeMe)
assert [1, "a", true, true, false, 5.3] - [true, 5.3] == [1, "a", false]
self
- a ListremoveMe
- a Collection of elements to remove
public static <T> List<T> minus(List<T> self, Iterable<?> removeMe)
class AbcIterable implements Iterable{ Iterator iterator() { "abc".iterator() } } assert "backtrack".toList() - new AbcIterable() == ["k", "t", "r", "k"]
self
- a ListremoveMe
- an Iterable of elements to remove
public static <T> List<T> minus(List<T> self, Object removeMe)
assert ["a", 5, 5, true] - 5 == ["a", true]
self
- a List objectremoveMe
- an element to remove from the list
public static <T> T[] minus(T[] self, Object removeMe)
self
- an object arrayremoveMe
- an element to remove from the array
public static <K,V> Map<K,V> minus(Map<K,V> self, Map removeMe)
self
- a map objectremoveMe
- the entries to remove from the map
public static Collection<?> flatten(Collection<?> self)
assert [1,2,3,4,5] == [1,[2,3],[[4]],[],5].flatten()
self
- a Collection to flatten
public static Collection flatten(Object[] self)
self
- an Array to flatten
public static Collection flatten(boolean[] self)
self
- a boolean Array to flatten
public static Collection flatten(byte[] self)
self
- a byte Array to flatten
public static Collection flatten(char[] self)
self
- a char Array to flatten
public static Collection flatten(short[] self)
self
- a short Array to flatten
public static Collection flatten(int[] self)
self
- an int Array to flatten
public static Collection flatten(long[] self)
self
- a long Array to flatten
public static Collection flatten(float[] self)
self
- a float Array to flatten
public static Collection flatten(double[] self)
self
- a double Array to flatten
public static <T> Collection<T> flatten(Collection<T> self, Closure<? extends T> flattenUsing)
self
- a CollectionflattenUsing
- a closure to determine how to flatten non-Array, non-Collection elements
public static <T> Collection<T> leftShift(Collection<T> self, T value)
def list = [1,2] list << 3 assert list == [1,2,3]
self
- a Collectionvalue
- an Object to be added to the collection.
public static <T> BlockingQueue<T> leftShift(BlockingQueue<T> self, T value) throws InterruptedException
def list = new java.util.concurrent.LinkedBlockingQueue () list << 3 << 2 << 1 assert list.iterator().collect{it} == [3,2,1]
self
- a Collectionvalue
- an Object to be added to the collection.
InterruptedException
public static <K,V> Map<K,V> leftShift(Map<K,V> self, Map.Entry<K,V> entry)
self
- a Mapentry
- a Map.Entry to be added to the Map.
public static <K,V> Map<K,V> leftShift(Map<K,V> self, Map<K,V> other)
map1 << map2
; otherwise it's just a synonym for
putAll
though it returns the original map rather than
being a void
method. Example usage:
def map = [a:1, b:2] map << [c:3, d:4] assert map == [a:1, b:2, c:3, d:4]
self
- a Mapother
- another Map whose entries should be added to the original Map.
public static StringBuffer leftShift(String self, Object value)
self
- a Stringvalue
- an Object
public static StringBuilder leftShift(CharSequence self, Object value)
self
- a CharSequencevalue
- an Object
public static StringBuilder leftShift(StringBuilder self, Object value)
self
- a StringBuildervalue
- an Object
protected static StringWriter createStringWriter(String self)
protected static StringBufferWriter createStringBufferWriter(StringBuffer self)
public static StringBuffer leftShift(StringBuffer self, Object value)
self
- a StringBuffervalue
- a value to append
public static Writer leftShift(Writer self, Object value) throws IOException
self
- a Writervalue
- a value to append
IOException
- if an I/O error occurs.public static Number leftShift(Number self, Number operand)
self
- a Number objectoperand
- the shift distance by which to left shift the number
public static Number rightShift(Number self, Number operand)
self
- a Number objectoperand
- the shift distance by which to right shift the number
public static Number rightShiftUnsigned(Number self, Number operand)
self
- a Number objectoperand
- the shift distance by which to right shift (unsigned) the number
public static void write(Writer self, Writable writable) throws IOException
self
- a Writerwritable
- an object implementing the Writable interface
IOException
- if an I/O error occurs.public static Writer leftShift(OutputStream self, Object value) throws IOException
self
- an OutputStreamvalue
- a value to append
IOException
- if an I/O error occurs.public static void leftShift(ObjectOutputStream self, Object value) throws IOException
self
- an ObjectOutputStreamvalue
- an object to write to the stream
IOException
- if an I/O error occurs.public static OutputStream leftShift(OutputStream self, InputStream in) throws IOException
self
- stream on which to writein
- stream to read from
IOException
- if an I/O error occurs.public static OutputStream leftShift(OutputStream self, byte[] value) throws IOException
self
- an OutputStreamvalue
- a value to append
IOException
- if an I/O error occurs.public static List<Byte> getAt(byte[] array, Range range)
array
- a byte arrayrange
- a range indicating the indices for the items to retrieve
public static List<Character> getAt(char[] array, Range range)
array
- a char arrayrange
- a range indicating the indices for the items to retrieve
public static List<Short> getAt(short[] array, Range range)
array
- a short arrayrange
- a range indicating the indices for the items to retrieve
public static List<Integer> getAt(int[] array, Range range)
array
- an int arrayrange
- a range indicating the indices for the items to retrieve
public static List<Long> getAt(long[] array, Range range)
array
- a long arrayrange
- a range indicating the indices for the items to retrieve
public static List<Float> getAt(float[] array, Range range)
array
- a float arrayrange
- a range indicating the indices for the items to retrieve
public static List<Double> getAt(double[] array, Range range)
array
- a double arrayrange
- a range indicating the indices for the items to retrieve
public static List<Boolean> getAt(boolean[] array, Range range)
array
- a boolean arrayrange
- a range indicating the indices for the items to retrieve
public static List<Byte> getAt(byte[] array, IntRange range)
array
- a byte arrayrange
- an IntRange indicating the indices for the items to retrieve
public static List<Character> getAt(char[] array, IntRange range)
array
- a char arrayrange
- an IntRange indicating the indices for the items to retrieve
public static List<Short> getAt(short[] array, IntRange range)
array
- a short arrayrange
- an IntRange indicating the indices for the items to retrieve
public static List<Integer> getAt(int[] array, IntRange range)
array
- an int arrayrange
- an IntRange indicating the indices for the items to retrieve
public static List<Long> getAt(long[] array, IntRange range)
array
- a long arrayrange
- an IntRange indicating the indices for the items to retrieve
public static List<Float> getAt(float[] array, IntRange range)
array
- a float arrayrange
- an IntRange indicating the indices for the items to retrieve
public static List<Double> getAt(double[] array, IntRange range)
array
- a double arrayrange
- an IntRange indicating the indices for the items to retrieve
public static List<Boolean> getAt(boolean[] array, IntRange range)
array
- a boolean arrayrange
- an IntRange indicating the indices for the items to retrieve
public static List<Byte> getAt(byte[] array, ObjectRange range)
array
- a byte arrayrange
- an ObjectRange indicating the indices for the items to retrieve
public static List<Character> getAt(char[] array, ObjectRange range)
array
- a char arrayrange
- an ObjectRange indicating the indices for the items to retrieve
public static List<Short> getAt(short[] array, ObjectRange range)
array
- a short arrayrange
- an ObjectRange indicating the indices for the items to retrieve
public static List<Integer> getAt(int[] array, ObjectRange range)
array
- an int arrayrange
- an ObjectRange indicating the indices for the items to retrieve
public static List<Long> getAt(long[] array, ObjectRange range)
array
- a long arrayrange
- an ObjectRange indicating the indices for the items to retrieve
public static List<Float> getAt(float[] array, ObjectRange range)
array
- a float arrayrange
- an ObjectRange indicating the indices for the items to retrieve
public static List<Double> getAt(double[] array, ObjectRange range)
array
- a double arrayrange
- an ObjectRange indicating the indices for the items to retrieve
public static List<Boolean> getAt(boolean[] array, ObjectRange range)
array
- a byte arrayrange
- an ObjectRange indicating the indices for the items to retrieve
public static List<Byte> getAt(byte[] array, Collection indices)
array
- a byte arrayindices
- a collection of indices for the items to retrieve
public static List<Character> getAt(char[] array, Collection indices)
array
- a char arrayindices
- a collection of indices for the items to retrieve
public static List<Short> getAt(short[] array, Collection indices)
array
- a short arrayindices
- a collection of indices for the items to retrieve
public static List<Integer> getAt(int[] array, Collection indices)
array
- an int arrayindices
- a collection of indices for the items to retrieve
public static List<Long> getAt(long[] array, Collection indices)
array
- a long arrayindices
- a collection of indices for the items to retrieve
public static List<Float> getAt(float[] array, Collection indices)
array
- a float arrayindices
- a collection of indices for the items to retrieve
public static List<Double> getAt(double[] array, Collection indices)
array
- a double arrayindices
- a collection of indices for the items to retrieve
public static List<Boolean> getAt(boolean[] array, Collection indices)
array
- a boolean arrayindices
- a collection of indices for the items to retrieve
public static boolean getAt(BitSet self, int index)
self
- a BitSetindex
- index to retrieve
BitSet
public static BitSet getAt(BitSet self, IntRange range)
self
- a BitSetrange
- a Range defining the desired subset
BitSet
,
IntRange
public static void putAt(BitSet self, IntRange range, boolean value)
self
- a BitSetrange
- the range of values to setvalue
- valueBitSet
,
Range
public static void putAt(BitSet self, int index, boolean value)
self
- a BitSetindex
- index of the entry to setvalue
- valueBitSet
public static int size(boolean[] array)
array
- a boolean array
Array.getLength(java.lang.Object)
public static int size(byte[] array)
array
- a byte array
Array.getLength(java.lang.Object)
public static int size(char[] array)
array
- a char array
Array.getLength(java.lang.Object)
public static int size(short[] array)
array
- a short array
Array.getLength(java.lang.Object)
public static int size(int[] array)
array
- an int array
Array.getLength(java.lang.Object)
public static int size(long[] array)
array
- a long array
Array.getLength(java.lang.Object)
public static int size(float[] array)
array
- a float array
Array.getLength(java.lang.Object)
public static int size(double[] array)
array
- a double array
Array.getLength(java.lang.Object)
public static List<Byte> toList(byte[] array)
array
- a byte array
public static List<Boolean> toList(boolean[] array)
array
- a boolean array
public static List<Character> toList(char[] array)
array
- a char array
public static List<Short> toList(short[] array)
array
- a short array
public static List<Integer> toList(int[] array)
array
- an int array
public static List<Long> toList(long[] array)
array
- a long array
public static List<Float> toList(float[] array)
array
- a float array
public static List<Double> toList(double[] array)
array
- a double array
public static Set<Byte> toSet(byte[] array)
array
- a byte array
public static Set<Boolean> toSet(boolean[] array)
array
- a boolean array
public static Set<Character> toSet(char[] array)
array
- a char array
public static Set<Short> toSet(short[] array)
array
- a short array
public static Set<Integer> toSet(int[] array)
array
- an int array
public static Set<Long> toSet(long[] array)
array
- a long array
public static Set<Float> toSet(float[] array)
array
- a float array
public static Set<Double> toSet(double[] array)
array
- a double array
public static <T> Set<T> toSet(Collection<T> self)
Example usage:
def result = [1, 2, 2, 2, 3].toSet() assert result instanceof Set assert result == [1, 2, 3] as Set
self
- a collection
public static <T> Set<T> toSet(Iterator<T> self)
self
- an iterator
public static <T> Set<T> toSet(Enumeration<T> self)
self
- an enumeration
protected static Object primitiveArrayGet(Object self, int idx)
self
- an array objectidx
- the index of interest
protected static List primitiveArrayGet(Object self, Range range)
self
- an array objectrange
- the range of indices of interest
protected static List primitiveArrayGet(Object self, Collection indices)
self
- an array objectindices
- the indices of interest
protected static Object primitiveArrayPut(Object self, int idx, Object newValue)
self
- an objectidx
- the index of interestnewValue
- the new value to be put into the index of interest
public static Character toCharacter(String self)
self
- a String
public static Boolean toBoolean(String self)
self
- a String
public static Boolean toBoolean(Boolean self)
self
- a Boolean
public static String[] split(String self)
self
- the string to split
public static CharSequence[] split(CharSequence self)
self
- the CharSequence to split
split(String)
public static String capitalize(String self)
assert 'h'.capitalize() == 'H' assert 'hello'.capitalize() == 'Hello' assert 'hello world'.capitalize() == 'Hello world' assert 'Hello World' == 'hello world'.split(' ').collect{ it.capitalize() }.join(' ')
self
- The string to capitalize
public static CharSequence capitalize(CharSequence self)
self
- The CharSequence to capitalize
capitalize(String)
public static String expand(String self)
self
- A String to expand
expand(java.lang.String, int)
public static CharSequence expand(CharSequence self)
self
- A CharSequence to expand
expand(java.lang.String)
public static String expand(String self, int tabStop)
self
- A String to expandtabStop
- The number of spaces a tab represents
public static CharSequence expand(CharSequence self, int tabStop)
self
- A CharSequence to expandtabStop
- The number of spaces a tab represents
expand(String, int)
public static String expandLine(String self, int tabStop)
self
- A line to expandtabStop
- The number of spaces a tab represents
public static CharSequence expandLine(CharSequence self, int tabStop)
self
- A line to expandtabStop
- The number of spaces a tab represents
expandLine(String, int)
public static String unexpand(String self)
self
- A String to unexpand
unexpand(java.lang.String, int)
public static CharSequence unexpand(CharSequence self)
self
- A CharSequence to unexpand
unexpand(java.lang.String)
public static String unexpand(String self, int tabStop)
self
- A String to unexpandtabStop
- The number of spaces a tab represents
public static CharSequence unexpand(CharSequence self, int tabStop)
self
- A CharSequence to unexpandtabStop
- The number of spaces a tab represents
unexpand(String, int)
public static String unexpandLine(String self, int tabStop)
self
- A line to unexpandtabStop
- The number of spaces a tab represents
public static CharSequence unexpandLine(CharSequence self, int tabStop)
self
- A line to unexpandtabStop
- The number of spaces a tab represents
unexpandLine(String, int)
public static String[] split(GString self)
self
- the GString to split
split(java.lang.String)
public static List<String> tokenize(String self, String token)
self
- a Stringtoken
- the delimiter
StringTokenizer.StringTokenizer(java.lang.String, java.lang.String)
public static List<CharSequence> tokenize(CharSequence self, CharSequence token)
self
- a CharSequencetoken
- the delimiter
tokenize(String, String)
public static List<String> tokenize(String self, Character token)
char pathSep = ':' assert "/tmp:/usr".tokenize(pathSep) == ["/tmp", "/usr"]
self
- a Stringtoken
- the delimiter
StringTokenizer.StringTokenizer(java.lang.String, java.lang.String)
public static List<CharSequence> tokenize(CharSequence self, Character token)
self
- a CharSequencetoken
- the delimiter
tokenize(String, Character)
public static List<String> tokenize(String self)
self
- a String
StringTokenizer.StringTokenizer(java.lang.String)
public static List<CharSequence> tokenize(CharSequence self)
self
- a CharSequence
tokenize(String)
public static String plus(String left, Object value)
left
- a Stringvalue
- any Object
public static CharSequence plus(CharSequence left, Object value)
left
- a CharSequencevalue
- any Object
public static String plus(Number value, String right)
value
- a Numberright
- a String
public static String plus(StringBuffer left, String value)
left
- a StringBuffervalue
- a String
public static String minus(String self, Object target)
self
- a Stringtarget
- an object representing the part to remove
public static CharSequence minus(CharSequence self, Object target)
self
- a CharSequencetarget
- an object representing the part to remove
minus(String, Object)
public static boolean contains(String self, String text)
Collection.contains(java.lang.Object)
to make Strings more polymorphic.
This method is not required on JDK 1.5 onwards
self
- a Stringtext
- a String to look for
public static boolean contains(CharSequence self, CharSequence text)
Collection.contains(java.lang.Object)
to make CharSequences more polymorphic.
self
- a CharSequencetext
- the CharSequence to look for
contains(String, String)
public static boolean contains(int[] self, Object value)
self
- the array we are searchingvalue
- the value being searched for
public static boolean contains(long[] self, Object value)
self
- the array we are searchingvalue
- the value being searched for
public static boolean contains(short[] self, Object value)
self
- the array we are searchingvalue
- the value being searched for
public static boolean contains(char[] self, Object value)
self
- the array we are searchingvalue
- the value being searched for
public static boolean contains(boolean[] self, Object value)
self
- the array within which we count the number of occurrencesvalue
- the value being searched for
public static boolean contains(double[] self, Object value)
self
- the array we are searchingvalue
- the value being searched for
public static boolean contains(float[] self, Object value)
self
- the array we are searchingvalue
- the value being searched for
public static boolean contains(byte[] self, Object value)
self
- the array we are searchingvalue
- the value being searched for
public static boolean contains(Object[] self, Object value)
self
- the array we are searchingvalue
- the value being searched for
public static int count(String self, String text)
self
- a Stringtext
- a substring
public static int count(CharSequence self, CharSequence text)
self
- a CharSequencetext
- a sub CharSequence
count(String, String)
public static String next(String self)
self
- a String
public static CharSequence next(CharSequence self)
self
- a CharSequence
next(String)
public static String previous(String self)
self
- a String
public static CharSequence previous(CharSequence self)
self
- a CharSequence
previous(String)
public static Process execute(String self) throws IOException
self
as a command-line process.
For more control over Process construction you can use
java.lang.ProcessBuilder
(JDK 1.5+).
self
- a command line String
IOException
- if an IOException occurs.public static Process execute(String self, String[] envp, File dir) throws IOException
self
with environment defined by envp
and under the working directory dir
.
For more control over Process construction you can use
java.lang.ProcessBuilder
(JDK 1.5+).
self
- a command line String to be executed.envp
- an array of Strings, each element of which
has environment variable settings in the format
name=value, or
null if the subprocess should inherit
the environment of the current process.dir
- the working directory of the subprocess, or
null if the subprocess should inherit
the working directory of the current process.
IOException
- if an IOException occurs.public static Process execute(String self, List envp, File dir) throws IOException
self
with environment defined
by envp
and under the working directory dir
.
For more control over Process construction you can use
java.lang.ProcessBuilder
(JDK 1.5+).
self
- a command line String to be executed.envp
- a List of Objects (converted to Strings using toString), each member of which
has environment variable settings in the format
name=value, or
null if the subprocess should inherit
the environment of the current process.dir
- the working directory of the subprocess, or
null if the subprocess should inherit
the working directory of the current process.
IOException
- if an IOException occurs.public static Process execute(String[] commandArray) throws IOException
String
array.
The first item in the array is the command; the others are the parameters.
For more control over Process construction you can use
java.lang.ProcessBuilder
(JDK 1.5+).
commandArray
- an array of String
containing the command name and
parameters as separate items in the array.
IOException
- if an IOException occurs.public static Process execute(String[] commandArray, String[] envp, File dir) throws IOException
String
array given in the first parameter,
with the environment defined by envp
and under the working directory dir
.
The first item in the array is the command; the others are the parameters.
For more control over Process construction you can use
java.lang.ProcessBuilder
(JDK 1.5+).
commandArray
- an array of String
containing the command name and
parameters as separate items in the array.envp
- an array of Strings, each member of which
has environment variable settings in the format
name=value, or
null if the subprocess should inherit
the environment of the current process.dir
- the working directory of the subprocess, or
null if the subprocess should inherit
the working directory of the current process.
IOException
- if an IOException occurs.public static Process execute(String[] commandArray, List envp, File dir) throws IOException
String
array given in the first parameter,
with the environment defined by envp
and under the working directory dir
.
The first item in the array is the command; the others are the parameters.
For more control over Process construction you can use
java.lang.ProcessBuilder
(JDK 1.5+).
commandArray
- an array of String
containing the command name and
parameters as separate items in the array.envp
- a List of Objects (converted to Strings using toString), each member of which
has environment variable settings in the format
name=value, or
null if the subprocess should inherit
the environment of the current process.dir
- the working directory of the subprocess, or
null if the subprocess should inherit
the working directory of the current process.
IOException
- if an IOException occurs.public static Process execute(List commands) throws IOException
For more control over Process construction you can use
java.lang.ProcessBuilder
(JDK 1.5+).
commands
- a list containing the command name and
parameters as separate items in the list.
IOException
- if an IOException occurs.public static Process execute(List commands, String[] envp, File dir) throws IOException
envp
and under the working directory dir
.
The first item in the list is the command; the others are the parameters. The toString()
method is called on items in the list to convert them to Strings.
For more control over Process construction you can use
java.lang.ProcessBuilder
(JDK 1.5+).
commands
- a List containing the command name and
parameters as separate items in the list.envp
- an array of Strings, each member of which
has environment variable settings in the format
name=value, or
null if the subprocess should inherit
the environment of the current process.dir
- the working directory of the subprocess, or
null if the subprocess should inherit
the working directory of the current process.
IOException
- if an IOException occurs.public static Process execute(List commands, List envp, File dir) throws IOException
envp
and under the working directory dir
.
The first item in the list is the command; the others are the parameters. The toString()
method is called on items in the list to convert them to Strings.
For more control over Process construction you can use
java.lang.ProcessBuilder
(JDK 1.5+).
commands
- a List containing the command name and
parameters as separate items in the list.envp
- a List of Objects (converted to Strings using toString), each member of which
has environment variable settings in the format
name=value, or
null if the subprocess should inherit
the environment of the current process.dir
- the working directory of the subprocess, or
null if the subprocess should inherit
the working directory of the current process.
IOException
- if an IOException occurs.public static String multiply(String self, Number factor)
self
- a String to be repeatedfactor
- the number of times the String should be repeated
IllegalArgumentException
- if the number of repetitions is < 0public static CharSequence multiply(CharSequence self, Number factor)
self
- a CharSequence to be repeatedfactor
- the number of times the CharSequence should be repeated
IllegalArgumentException
- if the number of repetitions is < 0public static String toString(boolean[] self)
self
- an array
public static String toString(byte[] self)
self
- an array
public static String toString(char[] self)
self
- an array
public static String toString(short[] self)
self
- an array
public static String toString(int[] self)
self
- an array
public static String toString(long[] self)
self
- an array
public static String toString(float[] self)
self
- an array
public static String toString(double[] self)
self
- an array
public static String toString(AbstractMap self)
self
- a Map
toMapString(java.util.Map)
public static String toMapString(Map self)
[one:1, two:2, three:3]
.
self
- a Map
public static String toMapString(Map self, int maxSize)
[one:1, two:2, three:3]
.
self
- a MapmaxSize
- stop after approximately this many characters and append '...'
public static String toString(AbstractCollection self)
[1, 2, a]
.
self
- a Collection
toListString(java.util.Collection)
public static String toListString(Collection self)
[1, 2, a]
.
self
- a Collection
public static String toListString(Collection self, int maxSize)
[1, 2, a]
.
self
- a CollectionmaxSize
- stop after approximately this many characters and append '...'
public static String toString(Object[] self)
self
- an Object[]
toArrayString(java.lang.Object[])
public static String toArrayString(Object[] self)
{1, 2, "a"}
.
self
- an Object[]
public static String toString(Object value)
value
- an object
public static Character next(Character self)
self
- a Character
public static Number next(Number self)
self
- a Number
public static Character previous(Character self)
self
- a Character
public static Number previous(Number self)
self
- a Number
public static Number plus(Character left, Number right)
left
- a Characterright
- a Number
Integer.valueOf(int)
public static Number plus(Number left, Character right)
left
- a Numberright
- a Character
Integer.valueOf(int)
public static Number plus(Character left, Character right)
left
- a Characterright
- a Character
plus(java.lang.Number, java.lang.Character)
public static int compareTo(Character left, Number right)
left
- a Characterright
- a Number
public static int compareTo(Number left, Character right)
left
- a Numberright
- a Character
public static int compareTo(Character left, Character right)
left
- a Characterright
- a Character
public static int compareTo(Number left, Number right)
left
- a Numberright
- another Number to compare to
public static Number minus(Character left, Number right)
left
- a Characterright
- a Number
public static Number minus(Number left, Character right)
left
- a Numberright
- a Character
public static Number minus(Character left, Character right)
left
- a Characterright
- a Character
public static Number multiply(Character left, Number right)
left
- a Characterright
- a Number
public static Number multiply(Number left, Character right)
left
- a Numberright
- a Character
public static Number multiply(Character left, Character right)
left
- a Characterright
- another Character
public static Number multiply(BigDecimal left, Double right)
left
- a BigDecimalright
- a Double
public static Number multiply(BigDecimal left, BigInteger right)
left
- a BigDecimalright
- a BigInteger
public static Number power(Number self, Number exponent)
self
- a Numberexponent
- a Number exponent
public static Number power(BigDecimal self, Integer exponent)
self
- a BigDecimalexponent
- an Integer exponent
public static Number power(BigInteger self, Integer exponent)
self
- a BigIntegerexponent
- an Integer exponent
public static Number power(Integer self, Integer exponent)
self
- an Integerexponent
- an Integer exponent
public static Number power(Long self, Integer exponent)
self
- a Longexponent
- an Integer exponent
public static Number div(Character left, Number right)
left
- a Characterright
- a Number
public static Number div(Number left, Character right)
left
- a Numberright
- a Character
public static Number div(Character left, Character right)
left
- a Characterright
- another Character
public static Number intdiv(Character left, Number right)
left
- a Characterright
- a Number
public static Number intdiv(Number left, Character right)
left
- a Numberright
- a Character
public static Number intdiv(Character left, Character right)
left
- a Characterright
- another Character
public static Number intdiv(Number left, Number right)
left
- a Numberright
- another Number
public static Number or(Number left, Number right)
left
- a Numberright
- another Number to bitwise OR
public static Number and(Number left, Number right)
left
- a Numberright
- another Number to bitwise AND
public static BitSet and(BitSet left, BitSet right)
left
- a BitSetright
- another BitSet to bitwise AND
public static BitSet xor(BitSet left, BitSet right)
left
- a BitSetright
- another BitSet to bitwise AND
public static BitSet bitwiseNegate(BitSet self)
self
- a BitSet
public static BitSet or(BitSet left, BitSet right)
left
- a BitSetright
- another BitSet to bitwise AND
public static Number xor(Number left, Number right)
left
- a Numberright
- another Number to bitwse XOR
public static Number mod(Number left, Number right)
left
- a Numberright
- another Number to mod
public static Number unaryMinus(Number left)
-10
left
- a Number
public static void times(Number self, Closure closure)
10.times { println it }Prints the numbers 0 through 9.
self
- a Numberclosure
- the closure to call a number of timespublic static void upto(Number self, Number to, Closure closure)
self
- a Numberto
- another Number to go up toclosure
- the closure to callpublic static void upto(long self, Number to, Closure closure)
self
- a longto
- the end numberclosure
- the code to execute for each numberpublic static void upto(Long self, Number to, Closure closure)
self
- a Longto
- the end numberclosure
- the code to execute for each numberpublic static void upto(float self, Number to, Closure closure)
self
- a floatto
- the end numberclosure
- the code to execute for each numberpublic static void upto(Float self, Number to, Closure closure)
self
- a Floatto
- the end numberclosure
- the code to execute for each numberpublic static void upto(double self, Number to, Closure closure)
self
- a doubleto
- the end numberclosure
- the code to execute for each numberpublic static void upto(Double self, Number to, Closure closure)
self
- a Doubleto
- the end numberclosure
- the code to execute for each numberpublic static void upto(BigInteger self, Number to, Closure closure)
0.upto( 10 ) { println it }Prints numbers 0 to 10
self
- a BigIntegerto
- the end numberclosure
- the code to execute for each numberpublic static void upto(BigDecimal self, Number to, Closure closure)
0.1.upto( 10 ) { println it }Prints numbers 0.1, 1.1, 2.1... to 9.1
self
- a BigDecimalto
- the end numberclosure
- the code to execute for each numberpublic static void downto(Number self, Number to, Closure closure)
self
- a Numberto
- another Number to go down toclosure
- the closure to callpublic static void downto(long self, Number to, Closure closure)
self
- a longto
- the end numberclosure
- the code to execute for each numberpublic static void downto(Long self, Number to, Closure closure)
self
- a Longto
- the end numberclosure
- the code to execute for each numberpublic static void downto(float self, Number to, Closure closure)
self
- a floatto
- the end numberclosure
- the code to execute for each numberpublic static void downto(Float self, Number to, Closure closure)
self
- a Floatto
- the end numberclosure
- the code to execute for each numberpublic static void downto(double self, Number to, Closure closure)
self
- a doubleto
- the end numberclosure
- the code to execute for each numberpublic static void downto(Double self, Number to, Closure closure)
self
- a Doubleto
- the end numberclosure
- the code to execute for each numberpublic static void downto(BigInteger self, Number to, Closure closure)
self
- a BigIntegerto
- the end numberclosure
- the code to execute for each numberpublic static void downto(BigDecimal self, Number to, Closure closure)
10.5.downto(0) { println it }Prints numbers 10.5, 9.5 ... to 0.5.
self
- a BigDecimalto
- the end numberclosure
- the code to execute for each numberpublic static void step(Number self, Number to, Number stepNumber, Closure closure)
0.step( 10, 2 ) { println it }Prints even numbers 0 through 8.
self
- a Number to start withto
- a Number to go up to, exclusivestepNumber
- a Number representing the step incrementclosure
- the closure to callpublic static int abs(Number number)
number
- a Number
public static long abs(Long number)
number
- a Long
public static float abs(Float number)
number
- a Float
public static double abs(Double number)
number
- a Double
public static int round(Float number)
number
- a Float
public static float round(Float number, int precision)
number
- a Floatprecision
- the number of decimal places to keep
public static float trunc(Float number, int precision)
number
- a Floatprecision
- the number of decimal places to keep
public static float trunc(Float number)
number
- a Double
public static long round(Double number)
number
- a Double
public static double round(Double number, int precision)
number
- a Doubleprecision
- the number of decimal places to keep
public static double trunc(Double number)
number
- a Double
public static double trunc(Double number, int precision)
number
- a Doubleprecision
- the number of decimal places to keep
public static Integer toInteger(String self)
self
- a String
public static Long toLong(String self)
self
- a String
public static Short toShort(String self)
self
- a String
public static Float toFloat(String self)
self
- a String
public static Double toDouble(String self)
self
- a String
public static BigInteger toBigInteger(String self)
self
- a String
public static BigDecimal toBigDecimal(String self)
self
- a String
public static boolean isInteger(String self)
self
- a String
public static boolean isLong(String self)
self
- a String
public static boolean isFloat(String self)
self
- a String
public static boolean isDouble(String self)
self
- a String
public static boolean isBigInteger(String self)
self
- a String
public static boolean isBigDecimal(String self)
self
- a String
public static boolean isNumber(String self)
self
- a String
isBigDecimal(java.lang.String)
public static Integer toInteger(CharSequence self)
self
- a CharSequence
toInteger(java.lang.String)
public static Long toLong(CharSequence self)
self
- a CharSequence
toLong(java.lang.String)
public static Short toShort(CharSequence self)
self
- a CharSequence
toShort(java.lang.String)
public static Float toFloat(CharSequence self)
self
- a CharSequence
toFloat(java.lang.String)
public static Double toDouble(CharSequence self)
self
- a CharSequence
toDouble(java.lang.String)
public static BigInteger toBigInteger(CharSequence self)
self
- a CharSequence
toBigInteger(java.lang.String)
public static BigDecimal toBigDecimal(CharSequence self)
self
- a CharSequence
toBigDecimal(java.lang.String)
public static boolean isInteger(CharSequence self)
self
- a CharSequence
isInteger(java.lang.String)
public static boolean isLong(CharSequence self)
self
- a CharSequence
isLong(java.lang.String)
public static boolean isFloat(CharSequence self)
self
- a CharSequence
isFloat(java.lang.String)
public static boolean isDouble(CharSequence self)
self
- a CharSequence
isDouble(java.lang.String)
public static boolean isBigInteger(CharSequence self)
self
- a CharSequence
isBigInteger(java.lang.String)
public static boolean isBigDecimal(CharSequence self)
self
- a CharSequence
isBigDecimal(java.lang.String)
public static boolean isNumber(CharSequence self)
self
- a CharSequence
isNumber(java.lang.String)
public static boolean isUpperCase(Character self)
self
- a Character
Character.isUpperCase(char)
public static boolean isLowerCase(Character self)
self
- a Character
Character.isLowerCase(char)
public static boolean isLetter(Character self)
self
- a Character
Character.isLetter(char)
public static boolean isDigit(Character self)
self
- a Character
Character.isDigit(char)
public static boolean isLetterOrDigit(Character self)
self
- a Character
Character.isLetterOrDigit(char)
public static boolean isWhitespace(Character self)
self
- a Character
Character.isWhitespace(char)
public static char toUpperCase(Character self)
self
- a Character to convert
Character.isUpperCase(char)
,
String.toUpperCase()
public static char toLowerCase(Character self)
self
- a Character to convert
Character.isLowerCase(char)
,
String.toLowerCase()
public static Integer toInteger(Number self)
self
- a Number
public static Long toLong(Number self)
self
- a Number
public static Float toFloat(Number self)
self
- a Number
public static Double toDouble(Number self)
self
- a Number
public static BigDecimal toBigDecimal(Number self)
self
- a Number
public static <T> T asType(Number self, Class<T> c)
asType(java.lang.Object, java.lang.Class)
:
self
- this numberc
- the desired type of the transformed result
public static BigInteger toBigInteger(Number self)
self
- a Number
public static Boolean and(Boolean left, Boolean right)
left
- left operatorright
- right operator
public static Boolean or(Boolean left, Boolean right)
left
- left operatorright
- right operator
public static Boolean implies(Boolean left, Boolean right)
left
- left operatorright
- right operator
public static Boolean xor(Boolean left, Boolean right)
left
- left operatorright
- right operator
public static ObjectOutputStream newObjectOutputStream(File file) throws IOException
file
- a file
IOException
- if an IOException occurs.public static ObjectOutputStream newObjectOutputStream(OutputStream outputStream) throws IOException
outputStream
- an output stream
IOException
- if an IOException occurs.public static <T> T withObjectOutputStream(File file, Closure<T> closure) throws IOException
file
- a Fileclosure
- a closure
IOException
- if an IOException occurs.withStream(java.io.OutputStream, groovy.lang.Closure)
public static <T> T withObjectOutputStream(OutputStream outputStream, Closure<T> closure) throws IOException
outputStream
- am output streamclosure
- a closure
IOException
- if an IOException occurs.withStream(java.io.OutputStream, groovy.lang.Closure)
public static ObjectInputStream newObjectInputStream(File file) throws IOException
file
- a file
IOException
- if an IOException occurs.public static ObjectInputStream newObjectInputStream(InputStream inputStream) throws IOException
inputStream
- an input stream
IOException
- if an IOException occurs.public static ObjectInputStream newObjectInputStream(InputStream inputStream, ClassLoader classLoader) throws IOException
inputStream
- an input streamclassLoader
- the class loader to use when loading the class
IOException
- if an IOException occurs.public static ObjectInputStream newObjectInputStream(File file, ClassLoader classLoader) throws IOException
file
- a fileclassLoader
- the class loader to use when loading the class
IOException
- if an IOException occurs.public static void eachObject(File self, Closure closure) throws IOException, ClassNotFoundException
self
- a Fileclosure
- a closure
IOException
- if an IOException occurs.
ClassNotFoundException
- if the class is not found.eachObject(java.io.ObjectInputStream, groovy.lang.Closure)
public static void eachObject(ObjectInputStream ois, Closure closure) throws IOException, ClassNotFoundException
ois
- an ObjectInputStream, closed after the operationclosure
- a closure
IOException
- if an IOException occurs.
ClassNotFoundException
- if the class is not found.public static <T> T withObjectInputStream(File file, Closure<T> closure) throws IOException
file
- a Fileclosure
- a closure
IOException
- if an IOException occurs.withStream(java.io.InputStream, groovy.lang.Closure)
public static <T> T withObjectInputStream(File file, ClassLoader classLoader, Closure<T> closure) throws IOException
file
- a FileclassLoader
- the class loader to use when loading the classclosure
- a closure
IOException
- if an IOException occurs.withStream(java.io.InputStream, groovy.lang.Closure)
public static <T> T withObjectInputStream(InputStream inputStream, Closure<T> closure) throws IOException
inputStream
- an input streamclosure
- a closure
IOException
- if an IOException occurs.withStream(java.io.InputStream, groovy.lang.Closure)
public static <T> T withObjectInputStream(InputStream inputStream, ClassLoader classLoader, Closure<T> closure) throws IOException
inputStream
- an input streamclassLoader
- the class loader to use when loading the classclosure
- a closure
IOException
- if an IOException occurs.withStream(java.io.InputStream, groovy.lang.Closure)
public static <T> T eachLine(String self, Closure<T> closure) throws IOException
self
- a Stringclosure
- a closure
IOException
- if an error occurseachLine(java.lang.String, int, groovy.lang.Closure)
public static <T> T eachLine(CharSequence self, Closure<T> closure) throws IOException
self
- a CharSequenceclosure
- a closure
IOException
- if an error occurseachLine(java.lang.String, groovy.lang.Closure)
public static <T> T eachLine(String self, int firstLine, Closure<T> closure) throws IOException
self
- a StringfirstLine
- the line number value used for the first line (default is 1, set to 0 to start counting from 0)closure
- a closure (arg 1 is line, optional arg 2 is line number)
IOException
- if an error occurspublic static <T> T eachLine(CharSequence self, int firstLine, Closure<T> closure) throws IOException
self
- a CharSequencefirstLine
- the line number value used for the first line (default is 1, set to 0 to start counting from 0)closure
- a closure (arg 1 is line, optional arg 2 is line number)
IOException
- if an error occurseachLine(java.lang.String, int, groovy.lang.Closure)
public static <T> T eachLine(File self, Closure<T> closure) throws IOException
self
- a Fileclosure
- a closure (arg 1 is line, optional arg 2 is line number starting at line 1)
IOException
- if an IOException occurs.eachLine(java.io.File, int, groovy.lang.Closure)
public static <T> T eachLine(File self, String charset, Closure<T> closure) throws IOException
self
- a Filecharset
- opens the file with a specified charsetclosure
- a closure (arg 1 is line, optional arg 2 is line number starting at line 1)
IOException
- if an IOException occurs.eachLine(java.io.File, java.lang.String, int, groovy.lang.Closure)
public static <T> T eachLine(File self, int firstLine, Closure<T> closure) throws IOException
self
- a FilefirstLine
- the line number value used for the first line (default is 1, set to 0 to start counting from 0)closure
- a closure (arg 1 is line, optional arg 2 is line number)
IOException
- if an IOException occurs.eachLine(java.io.Reader, int, groovy.lang.Closure)
public static <T> T eachLine(File self, String charset, int firstLine, Closure<T> closure) throws IOException
self
- a Filecharset
- opens the file with a specified charsetfirstLine
- the line number value used for the first line (default is 1, set to 0 to start counting from 0)closure
- a closure (arg 1 is line, optional arg 2 is line number)
IOException
- if an IOException occurs.eachLine(java.io.Reader, int, groovy.lang.Closure)
public static <T> T eachLine(InputStream stream, String charset, Closure<T> closure) throws IOException
stream
- a streamcharset
- opens the stream with a specified charsetclosure
- a closure (arg 1 is line, optional arg 2 is line number starting at line 1)
IOException
- if an IOException occurs.eachLine(java.io.InputStream, java.lang.String, int, groovy.lang.Closure)
public static <T> T eachLine(InputStream stream, String charset, int firstLine, Closure<T> closure) throws IOException
stream
- a streamcharset
- opens the stream with a specified charsetfirstLine
- the line number value used for the first line (default is 1, set to 0 to start counting from 0)closure
- a closure (arg 1 is line, optional arg 2 is line number)
IOException
- if an IOException occurs.eachLine(java.io.Reader, int, groovy.lang.Closure)
public static <T> T eachLine(InputStream stream, Closure<T> closure) throws IOException
stream
- a streamclosure
- a closure (arg 1 is line, optional arg 2 is line number starting at line 1)
IOException
- if an IOException occurs.eachLine(java.io.InputStream, int, groovy.lang.Closure)
public static <T> T eachLine(InputStream stream, int firstLine, Closure<T> closure) throws IOException
stream
- a streamfirstLine
- the line number value used for the first line (default is 1, set to 0 to start counting from 0)closure
- a closure (arg 1 is line, optional arg 2 is line number)
IOException
- if an IOException occurs.eachLine(java.io.Reader, int, groovy.lang.Closure)
public static <T> T eachLine(URL url, Closure<T> closure) throws IOException
url
- a URL to open and readclosure
- a closure to apply on each line (arg 1 is line, optional arg 2 is line number starting at line 1)
IOException
- if an IOException occurs.eachLine(java.net.URL, int, groovy.lang.Closure)
public static <T> T eachLine(URL url, int firstLine, Closure<T> closure) throws IOException
url
- a URL to open and readfirstLine
- the line number value used for the first line (default is 1, set to 0 to start counting from 0)closure
- a closure to apply on each line (arg 1 is line, optional arg 2 is line number)
IOException
- if an IOException occurs.eachLine(java.io.InputStream, int, groovy.lang.Closure)
public static <T> T eachLine(URL url, String charset, Closure<T> closure) throws IOException
url
- a URL to open and readcharset
- opens the stream with a specified charsetclosure
- a closure to apply on each line (arg 1 is line, optional arg 2 is line number starting at line 1)
IOException
- if an IOException occurs.eachLine(java.net.URL, java.lang.String, int, groovy.lang.Closure)
public static <T> T eachLine(URL url, String charset, int firstLine, Closure<T> closure) throws IOException
url
- a URL to open and readcharset
- opens the stream with a specified charsetfirstLine
- the line number value used for the first line (default is 1, set to 0 to start counting from 0)closure
- a closure to apply on each line (arg 1 is line, optional arg 2 is line number)
IOException
- if an IOException occurs.eachLine(java.io.Reader, int, groovy.lang.Closure)
public static <T> T eachLine(Reader self, Closure<T> closure) throws IOException
self
- a Reader, closed after the method returnsclosure
- a closure (arg 1 is line, optional arg 2 is line number starting at line 1)
IOException
- if an IOException occurs.eachLine(java.io.Reader, int, groovy.lang.Closure)
public static <T> T eachLine(Reader self, int firstLine, Closure<T> closure) throws IOException
self
- a Reader, closed after the method returnsfirstLine
- the line number value used for the first line (default is 1, set to 0 to start counting from 0)closure
- a closure which will be passed each line (or for 2 arg closures the line and line count)
IOException
- if an IOException occurs.public static <T> T splitEachLine(File self, String regex, Closure<T> closure) throws IOException
self
- a Fileregex
- the delimiting regular expressionclosure
- a closure
IOException
- if an IOException occurs.
PatternSyntaxException
- if the regular expression's syntax is invalidsplitEachLine(java.io.Reader, java.lang.String, groovy.lang.Closure)
public static <T> T splitEachLine(File self, Pattern pattern, Closure<T> closure) throws IOException
self
- a Filepattern
- the regular expression Pattern for the delimiterclosure
- a closure
IOException
- if an IOException occurs.splitEachLine(java.io.Reader, java.util.regex.Pattern, groovy.lang.Closure)
public static <T> T splitEachLine(File self, String regex, String charset, Closure<T> closure) throws IOException
self
- a Fileregex
- the delimiting regular expressioncharset
- opens the file with a specified charsetclosure
- a closure
IOException
- if an IOException occurs.
PatternSyntaxException
- if the regular expression's syntax is invalidsplitEachLine(java.io.Reader, java.lang.String, groovy.lang.Closure)
public static <T> T splitEachLine(File self, Pattern pattern, String charset, Closure<T> closure) throws IOException
self
- a Filepattern
- the regular expression Pattern for the delimitercharset
- opens the file with a specified charsetclosure
- a closure
IOException
- if an IOException occurs.splitEachLine(java.io.Reader, java.util.regex.Pattern, groovy.lang.Closure)
public static <T> T splitEachLine(URL self, String regex, Closure<T> closure) throws IOException
self
- a URL to open and readregex
- the delimiting regular expressionclosure
- a closure
IOException
- if an IOException occurs.
PatternSyntaxException
- if the regular expression's syntax is invalidsplitEachLine(java.io.Reader, java.lang.String, groovy.lang.Closure)
public static <T> T splitEachLine(URL self, Pattern pattern, Closure<T> closure) throws IOException
self
- a URL to open and readpattern
- the regular expression Pattern for the delimiterclosure
- a closure
IOException
- if an IOException occurs.splitEachLine(java.io.Reader, java.util.regex.Pattern, groovy.lang.Closure)
public static <T> T splitEachLine(URL self, String regex, String charset, Closure<T> closure) throws IOException
self
- a URL to open and readregex
- the delimiting regular expressioncharset
- opens the file with a specified charsetclosure
- a closure
IOException
- if an IOException occurs.
PatternSyntaxException
- if the regular expression's syntax is invalidsplitEachLine(java.io.Reader, java.lang.String, groovy.lang.Closure)
public static <T> T splitEachLine(URL self, Pattern pattern, String charset, Closure<T> closure) throws IOException
self
- a URL to open and readpattern
- the regular expression Pattern for the delimitercharset
- opens the file with a specified charsetclosure
- a closure
IOException
- if an IOException occurs.splitEachLine(java.io.Reader, java.util.regex.Pattern, groovy.lang.Closure)
public static <T> T splitEachLine(Reader self, String regex, Closure<T> closure) throws IOException
def s = 'The 3 quick\nbrown 4 fox' def result = '' new StringReader(s).splitEachLine(/\d/){ parts -> result += "${parts[0]}_${parts[1]}|" } assert result == 'The _ quick|brown _ fox|'
self
- a Reader, closed after the method returnsregex
- the delimiting regular expressionclosure
- a closure
IOException
- if an IOException occurs.
PatternSyntaxException
- if the regular expression's syntax is invalidString.split(java.lang.String)
public static <T> T splitEachLine(Reader self, Pattern pattern, Closure<T> closure) throws IOException
def s = 'The 3 quick\nbrown 4 fox' def result = '' new StringReader(s).splitEachLine(~/\d/){ parts -> result += "${parts[0]}_${parts[1]}|" } assert result == 'The _ quick|brown _ fox|'
self
- a Reader, closed after the method returnspattern
- the regular expression Pattern for the delimiterclosure
- a closure
IOException
- if an IOException occurs.
PatternSyntaxException
- if the regular expression's syntax is invalidString.split(java.lang.String)
public static <T> T splitEachLine(InputStream stream, String regex, String charset, Closure<T> closure) throws IOException
stream
- an InputStreamregex
- the delimiting regular expressioncharset
- opens the stream with a specified charsetclosure
- a closure
IOException
- if an IOException occurs.
PatternSyntaxException
- if the regular expression's syntax is invalidsplitEachLine(java.io.Reader, java.lang.String, groovy.lang.Closure)
public static <T> T splitEachLine(InputStream stream, Pattern pattern, String charset, Closure<T> closure) throws IOException
stream
- an InputStreampattern
- the regular expression Pattern for the delimitercharset
- opens the stream with a specified charsetclosure
- a closure
IOException
- if an IOException occurs.splitEachLine(java.io.Reader, java.util.regex.Pattern, groovy.lang.Closure)
public static <T> T splitEachLine(InputStream stream, String regex, Closure<T> closure) throws IOException
stream
- an InputStreamregex
- the delimiting regular expressionclosure
- a closure
IOException
- if an IOException occurs.
PatternSyntaxException
- if the regular expression's syntax is invalidsplitEachLine(java.io.Reader, java.lang.String, groovy.lang.Closure)
public static <T> T splitEachLine(InputStream stream, Pattern pattern, Closure<T> closure) throws IOException
stream
- an InputStreampattern
- the regular expression Pattern for the delimiterclosure
- a closure
IOException
- if an IOException occurs.splitEachLine(java.io.Reader, java.util.regex.Pattern, groovy.lang.Closure)
public static <T> T splitEachLine(String self, String regex, Closure<T> closure) throws IOException
self
- a Stringregex
- the delimiting regular expressionclosure
- a closure
IOException
- if an error occurs
PatternSyntaxException
- if the regular expression's syntax is invalidString.split(java.lang.String)
public static <T> T splitEachLine(CharSequence self, CharSequence regex, Closure<T> closure) throws IOException
self
- a CharSequenceregex
- the delimiting regular expressionclosure
- a closure
IOException
- if an error occurs
PatternSyntaxException
- if the regular expression's syntax is invalidsplitEachLine(String, String, Closure)
public static <T> T splitEachLine(String self, Pattern pattern, Closure<T> closure) throws IOException
self
- a Stringpattern
- the regular expression Pattern for the delimiterclosure
- a closure
IOException
- if an error occursPattern.split(java.lang.CharSequence)
public static <T> T splitEachLine(CharSequence self, Pattern pattern, Closure<T> closure) throws IOException
self
- a CharSequencepattern
- the regular expression Pattern for the delimiterclosure
- a closure
IOException
- if an error occurssplitEachLine(String, Pattern, Closure)
public static String readLine(Reader self) throws IOException
self
- a Reader
IOException
- if an IOException occurs.public static String denormalize(String self)
self
- a String object
public static CharSequence denormalize(CharSequence self)
self
- a CharSequence object
denormalize(String)
public static String normalize(String self)
self
- a String object
public static CharSequence normalize(CharSequence self)
self
- a CharSequence object
normalize(String)
public static List<String> readLines(String self) throws IOException
self
- a String object
IOException
- if an error occurspublic static List<CharSequence> readLines(CharSequence self) throws IOException
self
- a CharSequence object
IOException
- if an error occurspublic static List<String> readLines(File file) throws IOException
file
- a File
IOException
- if an IOException occurs.readLines(java.io.Reader)
public static List<String> readLines(File file, String charset) throws IOException
file
- a Filecharset
- opens the file with a specified charset
IOException
- if an IOException occurs.readLines(java.io.Reader)
public static List<String> readLines(InputStream stream) throws IOException
stream
- a stream
IOException
- if an IOException occurs.readLines(java.io.Reader)
public static List<String> readLines(InputStream stream, String charset) throws IOException
stream
- a streamcharset
- opens the stream with a specified charset
IOException
- if an IOException occurs.readLines(java.io.Reader)
public static List<String> readLines(URL self) throws IOException
self
- a URL
IOException
- if an IOException occurs.readLines(java.io.Reader)
public static List<String> readLines(URL self, String charset) throws IOException
self
- a URLcharset
- opens the URL with a specified charset
IOException
- if an IOException occurs.readLines(java.io.Reader)
public static List<String> readLines(Reader reader) throws IOException
reader
- a Reader
IOException
- if an IOException occurs.public static String getText(File file, String charset) throws IOException
file
- the file whose content we want to readcharset
- the charset used to read the content of the file
IOException
- if an IOException occurs.public static String getText(File file) throws IOException
file
- the file whose content we want to read
IOException
- if an IOException occurs.public static String getText(URL url) throws IOException
url
- URL to read content from
IOException
- if an IOException occurs.public static String getText(URL url, Map parameters) throws IOException
url
- URL to read content fromparameters
- connection parameters
IOException
- if an IOException occurs.public static String getText(URL url, String charset) throws IOException
url
- URL to read content fromcharset
- opens the stream with a specified charset
IOException
- if an IOException occurs.URLConnection.getInputStream()
public static String getText(URL url, Map parameters, String charset) throws IOException
url
- URL to read content fromparameters
- connection parameterscharset
- opens the stream with a specified charset
IOException
- if an IOException occurs.URLConnection.getInputStream()
public static String getText(InputStream is) throws IOException
is
- an input stream
IOException
- if an IOException occurs.public static String getText(InputStream is, String charset) throws IOException
is
- an input streamcharset
- opens the stream with a specified charset
IOException
- if an IOException occurs.public static String getText(Reader reader) throws IOException
reader
- a Reader whose content we want to read
IOException
- if an IOException occurs.getText(java.io.BufferedReader)
public static String getText(BufferedReader reader) throws IOException
reader
- a BufferedReader whose content we want to read
IOException
- if an IOException occurs.public static byte[] getBytes(File file) throws IOException
file
- the file whose content we want to read
IOException
- if an IOException occurs.public static byte[] getBytes(URL url) throws IOException
url
- URL to read content from
IOException
- if an IOException occurs.public static byte[] getBytes(InputStream is) throws IOException
is
- an input stream
IOException
- if an IOException occurs.public static void setBytes(File file, byte[] bytes) throws IOException
file
- the file to write tobytes
- the byte[] to write to the file
IOException
- if an IOException occurs.public static void setBytes(OutputStream os, byte[] bytes) throws IOException
os
- an output streambytes
- the byte[] to write to the output stream
IOException
- if an IOException occurs.public static void writeLine(BufferedWriter writer, String line) throws IOException
writer
- a BufferedWriterline
- the line to write
IOException
- if an IOException occurs.public static void write(File file, String text) throws IOException
file
- a Filetext
- the text to write to the File
IOException
- if an IOException occurs.public static void setText(File file, String text) throws IOException
file
- a Filetext
- the text to write to the File
IOException
- if an IOException occurs.write(java.io.File, java.lang.String)
public static void setText(File file, String text, String charset) throws IOException
myFile.setText('some text', charset)or with some help from
ExpandoMetaClass
, you could do something like:
myFile.metaClass.setText = { String s -> delegate.setText(s, 'UTF-8') } myfile.text = 'some text'
file
- A Filecharset
- The charset used when writing to the filetext
- The text to write to the File
IOException
- if an IOException occurs.write(java.io.File, java.lang.String, java.lang.String)
public static File leftShift(File file, Object text) throws IOException
file
- a Filetext
- the text to write to the File
IOException
- if an IOException occurs.public static File leftShift(File file, byte[] bytes) throws IOException
file
- a Filebytes
- the byte array to append to the end of the File
IOException
- if an IOException occurs.public static File leftShift(File file, InputStream data) throws IOException
append(java.io.File, java.io.InputStream)
file
- a Filedata
- an InputStream of data to write to the file
IOException
- if an IOException occurs.public static void write(File file, String text, String charset) throws IOException
file
- a Filetext
- the text to write to the Filecharset
- the charset used
IOException
- if an IOException occurs.public static void append(File file, Object text) throws IOException
file
- a Filetext
- the text to append at the end of the File
IOException
- if an IOException occurs.public static void append(File file, byte[] bytes) throws IOException
file
- a Filebytes
- the byte array to append to the end of the File
IOException
- if an IOException occurs.public static void append(File self, InputStream stream) throws IOException
self
- a Filestream
- stream to read data from.
IOException
- if an IOException occurs.public static void append(File file, Object text, String charset) throws IOException
file
- a Filetext
- the text to append at the end of the Filecharset
- the charset used
IOException
- if an IOException occurs.public static void eachFile(File self, FileType fileType, Closure closure) throws FileNotFoundException, IllegalArgumentException
self
- a file objectfileType
- if normal files or directories or both should be processedclosure
- the closure to invoke
FileNotFoundException
- if the given directory does not exist
IllegalArgumentException
- if the provided File object does not represent a directorypublic static void eachFile(File self, Closure closure) throws FileNotFoundException, IllegalArgumentException
self
- a File (that happens to be a folder/directory)closure
- a closure (first parameter is the 'child' file)
FileNotFoundException
- if the given directory does not exist
IllegalArgumentException
- if the provided File object does not represent a directoryFile.listFiles()
,
eachFile(java.io.File, groovy.io.FileType, groovy.lang.Closure)
public static void eachDir(File self, Closure closure) throws FileNotFoundException, IllegalArgumentException
self
- a File (that happens to be a folder/directory)closure
- a closure (first parameter is the subdirectory file)
FileNotFoundException
- if the given directory does not exist
IllegalArgumentException
- if the provided File object does not represent a directoryFile.listFiles()
,
eachFile(java.io.File, groovy.io.FileType, groovy.lang.Closure)
public static void eachFileRecurse(File self, FileType fileType, Closure closure) throws FileNotFoundException, IllegalArgumentException
self
- a file objectfileType
- if normal files or directories or both should be processedclosure
- the closure to invoke on each file
FileNotFoundException
- if the given directory does not exist
IllegalArgumentException
- if the provided File object does not represent a directorypublic static void traverse(File self, Map<String,Object> options, Closure closure) throws FileNotFoundException, IllegalArgumentException
closure
for each descendant file in this directory tree.
Sub-directories are recursively traversed as found.
The traversal can be adapted by providing various options in the options
Map according
to the following keys:FileType
enum to determine if normal files or directories or both are processedClosure
run before each directory is processed and optionally returning a FileVisitResult
value
which can be used to control subsequent processing.Closure
run after each directory is processed and optionally returning a FileVisitResult
value
which can be used to control subsequent processing.FileType.FILES
)isCase(java.lang.Object, java.lang.Object)
method). If set,
only files/dirs which match are candidates for visiting.isCase(java.lang.Object, java.lang.Object)
method). If set,
only files/dirs which match are candidates for visiting. (Must not be set if 'filter' is set)isCase(java.lang.Object, java.lang.Object)
method).
If set, any candidates which match won't be visited.isCase(java.lang.Object, java.lang.Object)
method).
If set, any candidates which match won't be visited. (Must not be set if 'excludeFilter' is set)Closure
which if set causes the files and subdirectories for each directory to be processed in sorted order.
Note that even when processing only files, the order of visited subdirectories will be affected by this parameter.def totalSize = 0 def count = 0 def sortByTypeThenName = { a, b -> a.isFile() != b.isFile() ? a.isFile() <=> b.isFile() : a.name <=> b.name } rootDir.traverse( type : FILES, nameFilter : ~/.*\.groovy/, preDir : { if (it.name == '.svn') return SKIP_SUBTREE }, postDir : { println "Found $count files in $it.name totalling $totalSize bytes" totalSize = 0; count = 0 }, postRoot : true sort : sortByTypeThenName ) {it -> totalSize += it.size(); count++ }
self
- a Fileoptions
- a Map of options to alter the traversal behaviorclosure
- the Closure to invoke on each file/directory and optionally returning a FileVisitResult
value
which can be used to control subsequent processing
FileNotFoundException
- if the given directory does not exist
IllegalArgumentException
- if the provided File object does not represent a directory or illegal filter combinations are suppliedsort(java.util.Collection, groovy.lang.Closure)
,
FileVisitResult
,
FileType
public static void traverse(File self, Closure closure) throws FileNotFoundException, IllegalArgumentException
traverse(java.io.File, java.util.Map, groovy.lang.Closure)
when
no options to alter the traversal behavior are required.
self
- a Fileclosure
- the Closure to invoke on each file/directory and optionally returning a FileVisitResult
value
which can be used to control subsequent processing
FileNotFoundException
- if the given directory does not exist
IllegalArgumentException
- if the provided File object does not represent a directorytraverse(java.io.File, java.util.Map, groovy.lang.Closure)
public static void traverse(File self, Map<String,Object> options) throws FileNotFoundException, IllegalArgumentException
traverse(java.io.File, java.util.Map, groovy.lang.Closure)
allowing the 'visit' closure
to be included in the options Map rather than as a parameter.
self
- a Fileoptions
- a Map of options to alter the traversal behavior
FileNotFoundException
- if the given directory does not exist
IllegalArgumentException
- if the provided File object does not represent a directory or illegal filter combinations are suppliedtraverse(java.io.File, java.util.Map, groovy.lang.Closure)
public static void eachFileRecurse(File self, Closure closure) throws FileNotFoundException, IllegalArgumentException
self
- a Fileclosure
- a closure
FileNotFoundException
- if the given directory does not exist
IllegalArgumentException
- if the provided File object does not represent a directoryeachFileRecurse(java.io.File, groovy.io.FileType, groovy.lang.Closure)
public static void eachDirRecurse(File self, Closure closure) throws FileNotFoundException, IllegalArgumentException
self
- a directoryclosure
- a closure
FileNotFoundException
- if the given directory does not exist
IllegalArgumentException
- if the provided File object does not represent a directoryeachFileRecurse(java.io.File, groovy.io.FileType, groovy.lang.Closure)
public static void eachFileMatch(File self, FileType fileType, Object nameFilter, Closure closure) throws FileNotFoundException, IllegalArgumentException
isCase(java.lang.Object, java.lang.Object)
method to determine if a match occurs. This method can be used
with different kinds of filters like regular expressions, classes, ranges etc.
Both regular files and subdirectories may be candidates for matching depending
on the value of fileType.
// collect names of files in baseDir matching supplied regex pattern import static groovy.io.FileType.* def names = [] baseDir.eachFileMatch FILES, ~/foo\d\.txt/, { names << it.name } assert names == ['foo1.txt', 'foo2.txt'] // remove all *.bak files in baseDir baseDir.eachFileMatch FILES, ~/.*\.bak/, { File bak -> bak.delete() } // print out files > 4K in size from baseDir baseDir.eachFileMatch FILES, { new File(baseDir, it).size() > 4096 }, { println "$it.name ${it.size()}" }
self
- a filefileType
- whether normal files or directories or both should be processednameFilter
- the filter to perform on the name of the file/directory (using the isCase(java.lang.Object, java.lang.Object)
method)closure
- the closure to invoke
FileNotFoundException
- if the given directory does not exist
IllegalArgumentException
- if the provided File object does not represent a directorypublic static void eachFileMatch(File self, Object nameFilter, Closure closure) throws FileNotFoundException, IllegalArgumentException
isCase(java.lang.Object, java.lang.Object)
method to determine if a match occurs. This method can be used
with different kinds of filters like regular expressions, classes, ranges etc.
Both regular files and subdirectories are matched.
self
- a filenameFilter
- the nameFilter to perform on the name of the file (using the isCase(java.lang.Object, java.lang.Object)
method)closure
- the closure to invoke
FileNotFoundException
- if the given directory does not exist
IllegalArgumentException
- if the provided File object does not represent a directoryeachFileMatch(java.io.File, groovy.io.FileType, java.lang.Object, groovy.lang.Closure)
public static void eachDirMatch(File self, Object nameFilter, Closure closure) throws FileNotFoundException, IllegalArgumentException
isCase(java.lang.Object, java.lang.Object)
method to determine if a match occurs. This method can be used
with different kinds of filters like regular expressions, classes, ranges etc.
Only subdirectories are matched; regular files are ignored.
self
- a filenameFilter
- the nameFilter to perform on the name of the directory (using the isCase(java.lang.Object, java.lang.Object)
method)closure
- the closure to invoke
FileNotFoundException
- if the given directory does not exist
IllegalArgumentException
- if the provided File object does not represent a directoryeachFileMatch(java.io.File, groovy.io.FileType, java.lang.Object, groovy.lang.Closure)
public static boolean deleteDir(File self)
The method returns
self
- a File
public static boolean renameTo(File self, String newPathName)
File.renameTo(File)
self
- a FilenewPathName
- The new pathname for the named file
true
if and only if the renaming succeeded;
false
otherwisepublic static TimerTask runAfter(Timer timer, int delay, Closure closure)
timer
- a timer objectdelay
- the delay in milliseconds before running the closure codeclosure
- the closure to invoke
public static BufferedReader newReader(File file) throws IOException
file
- a File
IOException
- if an IOException occurs.public static BufferedReader newReader(File file, String charset) throws FileNotFoundException, UnsupportedEncodingException
file
- a Filecharset
- the charset for this File
FileNotFoundException
- if the File was not found
UnsupportedEncodingException
- if the encoding specified is not supportedpublic static BufferedReader newReader(InputStream self)
self
- an input stream
public static BufferedReader newReader(InputStream self, String charset) throws UnsupportedEncodingException
self
- an input streamcharset
- the charset for this input stream
UnsupportedEncodingException
- if the encoding specified is not supportedpublic static <T> T withReader(File file, Closure<T> closure) throws IOException
file
- a file objectclosure
- a closure
IOException
- if an IOException occurs.public static <T> T withReader(File file, String charset, Closure<T> closure) throws IOException
file
- a file objectcharset
- the charset for this input streamclosure
- a closure
IOException
- if an IOException occurs.public static BufferedOutputStream newOutputStream(File file) throws IOException
file
- a file object
IOException
- if an IOException occurs.public static DataOutputStream newDataOutputStream(File file) throws IOException
file
- a file object
IOException
- if an IOException occurs.public static Object withOutputStream(File file, Closure closure) throws IOException
file
- a Fileclosure
- a closure
IOException
- if an IOException occurs.withStream(java.io.OutputStream, groovy.lang.Closure)
public static Object withInputStream(File file, Closure closure) throws IOException
file
- a Fileclosure
- a closure
IOException
- if an IOException occurs.withStream(java.io.InputStream, groovy.lang.Closure)
public static <T> T withInputStream(URL url, Closure<T> closure) throws IOException
url
- a URLclosure
- a closure
IOException
- if an IOException occurs.withStream(java.io.InputStream, groovy.lang.Closure)
public static <T> T withDataOutputStream(File file, Closure<T> closure) throws IOException
file
- a Fileclosure
- a closure
IOException
- if an IOException occurs.withStream(java.io.OutputStream, groovy.lang.Closure)
public static <T> T withDataInputStream(File file, Closure<T> closure) throws IOException
file
- a Fileclosure
- a closure
IOException
- if an IOException occurs.withStream(java.io.InputStream, groovy.lang.Closure)
public static BufferedWriter newWriter(File file) throws IOException
file
- a File
IOException
- if an IOException occurs.public static BufferedWriter newWriter(File file, boolean append) throws IOException
file
- a Fileappend
- true if data should be appended to the file
IOException
- if an IOException occurs.public static BufferedWriter newWriter(File file, String charset, boolean append) throws IOException
file
- a Filecharset
- the name of the encoding used to write in this fileappend
- true if in append mode
IOException
- if an IOException occurs.public static BufferedWriter newWriter(File file, String charset) throws IOException
file
- a Filecharset
- the name of the encoding used to write in this file
IOException
- if an IOException occurs.public static <T> T withWriter(File file, Closure<T> closure) throws IOException
file
- a Fileclosure
- a closure
IOException
- if an IOException occurs.public static <T> T withWriter(File file, String charset, Closure<T> closure) throws IOException
file
- a Filecharset
- the charset usedclosure
- a closure
IOException
- if an IOException occurs.public static <T> T withWriterAppend(File file, String charset, Closure<T> closure) throws IOException
file
- a Filecharset
- the charset usedclosure
- a closure
IOException
- if an IOException occurs.public static <T> T withWriterAppend(File file, Closure<T> closure) throws IOException
file
- a Fileclosure
- a closure
IOException
- if an IOException occurs.public static PrintWriter newPrintWriter(File file) throws IOException
file
- a File
IOException
- if an IOException occurs.public static PrintWriter newPrintWriter(File file, String charset) throws IOException
file
- a Filecharset
- the charset
IOException
- if an IOException occurs.public static PrintWriter newPrintWriter(Writer writer)
writer
- a writer
public static <T> T withPrintWriter(File file, Closure<T> closure) throws IOException
file
- a Fileclosure
- the closure to invoke with the PrintWriter
IOException
- if an IOException occurs.public static <T> T withPrintWriter(File file, String charset, Closure<T> closure) throws IOException
file
- a Filecharset
- the charsetclosure
- the closure to invoke with the PrintWriter
IOException
- if an IOException occurs.public static <T> T withPrintWriter(Writer writer, Closure<T> closure) throws IOException
writer
- a writerclosure
- the closure to invoke with the PrintWriter
IOException
- if an IOException occurs.public static <T> T withWriter(Writer writer, Closure<T> closure) throws IOException
writer
- the writer which is used and then closedclosure
- the closure that the writer is passed into
IOException
- if an IOException occurs.public static <T> T withReader(Reader reader, Closure<T> closure) throws IOException
reader
- the reader which is used and then closedclosure
- the closure that the writer is passed into
IOException
- if an IOException occurs.public static <T> T withStream(InputStream stream, Closure<T> closure) throws IOException
stream
- the stream which is used and then closedclosure
- the closure that the stream is passed into
IOException
- if an IOException occurs.public static <T> T withReader(URL url, Closure<T> closure) throws IOException
url
- a URLclosure
- the closure to invoke with the reader
IOException
- if an IOException occurs.public static <T> T withReader(URL url, String charset, Closure<T> closure) throws IOException
url
- a URLcharset
- the charset usedclosure
- the closure to invoke with the reader
IOException
- if an IOException occurs.public static <T> T withReader(InputStream in, Closure<T> closure) throws IOException
in
- a streamclosure
- the closure to invoke with the InputStream
IOException
- if an IOException occurs.InputStreamReader
public static <T> T withReader(InputStream in, String charset, Closure<T> closure) throws IOException
in
- a streamcharset
- the charset used to decode the streamclosure
- the closure to invoke with the reader
IOException
- if an IOException occurs.InputStreamReader
public static <T> T withWriter(OutputStream stream, Closure<T> closure) throws IOException
stream
- the stream which is used and then closedclosure
- the closure that the writer is passed into
IOException
- if an IOException occurs.withWriter(java.io.Writer, groovy.lang.Closure)
public static <T> T withWriter(OutputStream stream, String charset, Closure<T> closure) throws IOException
stream
- the stream which is used and then closedcharset
- the charset usedclosure
- the closure that the writer is passed into
IOException
- if an IOException occurs.withWriter(java.io.Writer, groovy.lang.Closure)
public static <T> T withStream(OutputStream os, Closure<T> closure) throws IOException
os
- the stream which is used and then closedclosure
- the closure that the stream is passed into
IOException
- if an IOException occurs.public static BufferedInputStream newInputStream(File file) throws FileNotFoundException
file
- a File
FileNotFoundException
- if the file is not found.public static BufferedInputStream newInputStream(URL url) throws MalformedURLException, IOException
url
- a URL
MalformedURLException
- is thrown if the URL is not well formed
IOException
- if an I/O error occurs while creating the input streampublic static BufferedInputStream newInputStream(URL url, Map parameters) throws MalformedURLException, IOException
url
- a URLparameters
- connection parameters
MalformedURLException
- is thrown if the URL is not well formed
IOException
- if an I/O error occurs while creating the input streampublic static BufferedReader newReader(URL url) throws MalformedURLException, IOException
url
- a URL
MalformedURLException
- is thrown if the URL is not well formed
IOException
- if an I/O error occurs while creating the input streampublic static BufferedReader newReader(URL url, Map parameters) throws MalformedURLException, IOException
url
- a URLparameters
- connection parameters
MalformedURLException
- is thrown if the URL is not well formed
IOException
- if an I/O error occurs while creating the input streampublic static BufferedReader newReader(URL url, String charset) throws MalformedURLException, IOException
url
- a URLcharset
- opens the stream with a specified charset
MalformedURLException
- is thrown if the URL is not well formed
IOException
- if an I/O error occurs while creating the input streampublic static BufferedReader newReader(URL url, Map parameters, String charset) throws MalformedURLException, IOException
url
- a URLparameters
- connection parameterscharset
- opens the stream with a specified charset
MalformedURLException
- is thrown if the URL is not well formed
IOException
- if an I/O error occurs while creating the input streampublic static DataInputStream newDataInputStream(File file) throws FileNotFoundException
file
- a File
FileNotFoundException
- if the file is not found.public static void eachByte(File self, Closure closure) throws IOException
self
- a Fileclosure
- a closure
IOException
- if an IOException occurs.eachByte(java.io.InputStream, groovy.lang.Closure)
public static void eachByte(File self, int bufferLen, Closure closure) throws IOException
self
- a FilebufferLen
- the length of the buffer to use.closure
- a 2 parameter closure which is passed the byte[] and a number of bytes successfully read.
IOException
- if an IOException occurs.eachByte(java.io.InputStream, int, groovy.lang.Closure)
public static void eachByte(Byte[] self, Closure closure)
self
- a Byte arrayclosure
- a closureeach(java.lang.Object, groovy.lang.Closure)
public static void eachByte(byte[] self, Closure closure)
self
- a byte arrayclosure
- a closureeach(java.lang.Object, groovy.lang.Closure)
public static void eachByte(InputStream is, Closure closure) throws IOException
is
- stream to iterate over, closed after the method callclosure
- closure to apply to each byte
IOException
- if an IOException occurs.public static void eachByte(InputStream is, int bufferLen, Closure closure) throws IOException
is
- stream to iterate over, closed after the method call.bufferLen
- the length of the buffer to use.closure
- a 2 parameter closure which is passed the byte[] and a number of bytes successfully read.
IOException
- if an IOException occurs.public static void eachByte(URL url, Closure closure) throws IOException
url
- url to iterate overclosure
- closure to apply to each byte
IOException
- if an IOException occurs.eachByte(java.io.InputStream, groovy.lang.Closure)
public static void eachByte(URL url, int bufferLen, Closure closure) throws IOException
url
- url to iterate overbufferLen
- the length of the buffer to use.closure
- a 2 parameter closure which is passed the byte[] and a number of bytes successfully read.
IOException
- if an IOException occurs.eachByte(java.io.InputStream, int, groovy.lang.Closure)
public static void transformChar(Reader self, Writer writer, Closure closure) throws IOException
self
- a Reader objectwriter
- a Writer to receive the transformed charactersclosure
- a closure that performs the required transformation
IOException
- if an IOException occurs.public static void transformLine(Reader reader, Writer writer, Closure closure) throws IOException
reader
- Lines of text to be transformed. Reader is closed afterwards.writer
- Where transformed lines are written. Writer is closed afterwards.closure
- Single parameter closure that is called to transform each line of
text from the reader, before writing it to the writer.
IOException
- if an IOException occurs.public static void filterLine(Reader reader, Writer writer, Closure closure) throws IOException
reader
- a reader, closed after the callwriter
- a writer, closed after the callclosure
- the closure which returns booleans
IOException
- if an IOException occurs.public static Writable filterLine(File self, Closure closure) throws IOException
self
- a Fileclosure
- a closure which returns a boolean indicating to filter
the line or not
IOException
- if self
is not readablefilterLine(java.io.Reader, groovy.lang.Closure)
public static Writable filterLine(File self, String charset, Closure closure) throws IOException
self
- a Filecharset
- opens the file with a specified charsetclosure
- a closure which returns a boolean indicating to filter
the line or not
IOException
- if an IOException occursfilterLine(java.io.Reader, groovy.lang.Closure)
public static void filterLine(File self, Writer writer, Closure closure) throws IOException
self
- a Filewriter
- a writer destination to write filtered lines toclosure
- a closure which takes each line as a parameter and returns
true
if the line should be written to this writer.
IOException
- if self
is not readablefilterLine(java.io.Reader, java.io.Writer, groovy.lang.Closure)
public static void filterLine(File self, Writer writer, String charset, Closure closure) throws IOException
self
- a Filewriter
- a writer destination to write filtered lines tocharset
- opens the file with a specified charsetclosure
- a closure which takes each line as a parameter and returns
true
if the line should be written to this writer.
IOException
- if an IO error occursfilterLine(java.io.Reader, java.io.Writer, groovy.lang.Closure)
public static Writable filterLine(Reader reader, Closure closure)
true
if the line should be passed to the writer.
reader
- this readerclosure
- a closure used for filtering
public static Writable filterLine(InputStream self, Closure predicate)
true
if the line should be passed to the writer.
self
- an input streampredicate
- a closure which returns boolean and takes a line
filterLine(java.io.Reader, groovy.lang.Closure)
public static Writable filterLine(InputStream self, String charset, Closure predicate) throws UnsupportedEncodingException
true
if the line should be passed to the writer.
self
- an input streamcharset
- opens the stream with a specified charsetpredicate
- a closure which returns boolean and takes a line
UnsupportedEncodingException
- if the encoding specified is not supportedfilterLine(java.io.Reader, groovy.lang.Closure)
public static void filterLine(InputStream self, Writer writer, Closure predicate) throws IOException
true
if the line should be passed to the
writer.
self
- the InputStreamwriter
- a writer to write output topredicate
- a closure which returns true if a line should be accepted
IOException
- if an IOException occurs.filterLine(java.io.Reader, java.io.Writer, groovy.lang.Closure)
public static void filterLine(InputStream self, Writer writer, String charset, Closure predicate) throws IOException
true
if the line should be passed to the
writer.
self
- the InputStreamwriter
- a writer to write output tocharset
- opens the stream with a specified charsetpredicate
- a closure which returns true if a line should be accepted
IOException
- if an IOException occurs.filterLine(java.io.Reader, java.io.Writer, groovy.lang.Closure)
public static Writable filterLine(URL self, Closure predicate) throws IOException
true
if the line should be passed to the writer.
self
- a URLpredicate
- a closure which returns boolean and takes a line
IOException
- if an IO exception occursfilterLine(java.io.Reader, groovy.lang.Closure)
public static Writable filterLine(URL self, String charset, Closure predicate) throws IOException
true
if the line should be passed to the writer.
self
- the URLcharset
- opens the URL with a specified charsetpredicate
- a closure which returns boolean and takes a line
IOException
- if an IO exception occursfilterLine(java.io.Reader, groovy.lang.Closure)
public static void filterLine(URL self, Writer writer, Closure predicate) throws IOException
true
if the line should be passed to the
writer.
self
- the URLwriter
- a writer to write output topredicate
- a closure which returns true if a line should be accepted
IOException
- if an IOException occurs.filterLine(java.io.Reader, java.io.Writer, groovy.lang.Closure)
public static void filterLine(URL self, Writer writer, String charset, Closure predicate) throws IOException
true
if the line should be passed to the
writer.
self
- the URLwriter
- a writer to write output tocharset
- opens the URL with a specified charsetpredicate
- a closure which returns true if a line should be accepted
IOException
- if an IOException occurs.filterLine(java.io.Reader, java.io.Writer, groovy.lang.Closure)
public static byte[] readBytes(File file) throws IOException
file
- a File
IOException
- if an IOException occurs.public static <T> T withStreams(Socket socket, Closure<T> closure) throws IOException
socket
- a Socketclosure
- a Closure
IOException
- if an IOException occurs.public static <T> T withObjectStreams(Socket socket, Closure<T> closure) throws IOException
socket
- this Socketclosure
- a Closure
IOException
- if an IOException occurs.public static Writer leftShift(Socket self, Object value) throws IOException
self
- a Socketvalue
- a value to append
IOException
- if an IOException occurs.public static OutputStream leftShift(Socket self, byte[] value) throws IOException
self
- a Socketvalue
- a value to append
IOException
- if an IOException occurs.public static Socket accept(ServerSocket serverSocket, Closure closure) throws IOException
serverSocket
- a ServerSocketclosure
- a Closure
IOException
- if an IOException occurs.ServerSocket.accept()
public static Socket accept(ServerSocket serverSocket, boolean runInANewThread, Closure closure) throws IOException
serverSocket
- a ServerSocketrunInANewThread
- This flag should be true, if the closure should be invoked in a new thread, else false.closure
- a Closure
IOException
- if an IOException occurs.ServerSocket.accept()
public static File asWritable(File file)
Writable
.
file
- a File
public static <T> T asType(File f, Class<T> c)
Writable
or delegates to default
asType(java.lang.Object, java.lang.Class)
.
f
- a Filec
- the desired class
public static File asWritable(File file, String encoding)
file
- a Fileencoding
- the encoding to be used when reading the file's contents
public static List<String> toList(String self)
self
- a String
public static List<CharSequence> toList(CharSequence self)
self
- a CharSequence
toSet(String)
public static Set<String> toSet(String self)
Example usage:
assert 'groovy'.toSet() == ['v', 'g', 'r', 'o', 'y'] as Set assert "abc".toSet().iterator()[0] instanceof String
self
- a String
public static Set<CharSequence> toSet(CharSequence self)
self
- a CharSequence
toSet(String)
public static char[] getChars(String self)
self
- a String
String.toCharArray()
public static char[] getChars(CharSequence self)
self
- a CharSequence
getChars(String)
public static <T> T asType(GString self, Class<T> c)
asType(java.lang.Object, java.lang.Class)
self
- a GStringc
- the desired class
public static <T> T asType(String self, Class<T> c)
Provides a method to perform custom 'dynamic' type conversion
to the given class using the as
operator.
'123' as Double
By default, the following types are supported:
asType(java.lang.Object, java.lang.Class)
.
self
- a Stringc
- the desired class
public static <T> T asType(CharSequence self, Class<T> c)
Provides a method to perform custom 'dynamic' type conversion
to the given class using the as
operator.
self
- a CharSequencec
- the desired class
asType(String, Class)
public static String eachMatch(String self, String regex, Closure closure)
self
- the source stringregex
- a Regex stringclosure
- a closure with one parameter or as much parameters as groups
public static String eachMatch(CharSequence self, CharSequence regex, Closure closure)
self
- the source CharSequenceregex
- a Regex CharSequenceclosure
- a closure with one parameter or as much parameters as groups
eachMatch(String, String, groovy.lang.Closure)
public static String eachMatch(String self, Pattern pattern, Closure closure)
self
- the source stringpattern
- a regex Patternclosure
- a closure with one parameter or as much parameters as groups
public static String eachMatch(CharSequence self, Pattern pattern, Closure closure)
self
- the source CharSequencepattern
- a regex Patternclosure
- a closure with one parameter or as much parameters as groups
eachMatch(String, Pattern, groovy.lang.Closure)
public static int findIndexOf(Object self, Closure closure)
self
- the iteration object over which to iterateclosure
- the filter to perform a match on the collection
public static int findIndexOf(Object self, int startIndex, Closure closure)
self
- the iteration object over which to iteratestartIndex
- start matching from this indexclosure
- the filter to perform a match on the collection
public static int findLastIndexOf(Object self, Closure closure)
self
- the iteration object over which to iterateclosure
- the filter to perform a match on the collection
public static int findLastIndexOf(Object self, int startIndex, Closure closure)
self
- the iteration object over which to iteratestartIndex
- start matching from this indexclosure
- the filter to perform a match on the collection
public static List<Number> findIndexValues(Object self, Closure closure)
self
- the iteration object over which to iterateclosure
- the filter to perform a match on the collection
public static List<Number> findIndexValues(Object self, Number startIndex, Closure closure)
self
- the iteration object over which to iteratestartIndex
- start matching from this indexclosure
- the filter to perform a match on the collection
public static ClassLoader getRootLoader(ClassLoader self)
null
will be returned. The name is used for comparison because
a direct comparison using == may fail as the class may be loaded through
different classloaders.
self
- a ClassLoader
RootLoader
public static <T> T asType(Object obj, Class<T> type)
obj
- the object to converttype
- the goal type
public static <T> T newInstance(Class<T> c)
c
- a class
public static <T> T newInstance(Class<T> c, Object[] args)
newInstance(null)
or simply
newInstance()
for the default (no-arg) constructor.
c
- a classargs
- the constructor arguments
public static MetaClass getMetaClass(Class c)
String.metaClass.myMethod = { println "foo" }
c
- The java.lang.Class instance
public static MetaClass getMetaClass(Object obj)
obj
- The object in question
public static MetaClass getMetaClass(GroovyObject obj)
obj
- The object in question
public static void setMetaClass(Class self, MetaClass metaClass)
self
- the class whose metaclass we wish to setmetaClass
- the new MetaClasspublic static void setMetaClass(Object self, MetaClass metaClass)
self
- the object whose metaclass we want to setmetaClass
- the new metaclass valuepublic static MetaClass metaClass(Class self, Closure closure)
self
- the class whose metaclass we wish to updateclosure
- the closure representing the new metaclass
GroovyRuntimeException
- if the metaclass can't be set for this classpublic static MetaClass metaClass(Object self, Closure closure)
self
- the object whose metaclass we wish to updateclosure
- the closure representing the new metaclass
GroovyRuntimeException
- if the metaclass can't be set for this objectpublic static <T> Iterator<T> iterator(T[] a)
a
- an array
DefaultTypeTransformation.asCollection(java.lang.Object[])
public static Iterator iterator(Object o)
o
- an object
DefaultTypeTransformation.asCollection(java.lang.Object)
public static <T> Iterator<T> iterator(Enumeration<T> enumeration)
remove()
method is unsupported since the
underlying Enumeration does not provide a mechanism for removing items.
enumeration
- an Enumeration object
public static Iterator iterator(Matcher matcher)
Iterator
which traverses each match.
matcher
- a Matcher object
Matcher.group()
public static Iterator<String> iterator(Reader self)
self
- a Reader object
BufferedReader.readLine()
public static Iterator<Byte> iterator(InputStream self)
self
- an InputStream object
public static Iterator<Byte> iterator(DataInputStream self)
self
- a DataInputStream object
public static <T> Iterator<T> iterator(Iterator<T> self)
self
- an iterator object
public static List<MetaMethod> respondsTo(Object self, String name, Object[] argTypes)
Returns an object satisfying Groovy truth if the implementing MetaClass responds to a method with the given name and arguments types.
Note that this method's return value is based on realised methods and does not take into account objects or classes that implement invokeMethod or methodMissing
This method is "safe" in that it will always return a value and never throw an exception
self
- The object to inspectname
- The name of the method of interestargTypes
- The argument types to match against
MetaObjectProtocol.respondsTo(java.lang.Object, java.lang.String, java.lang.Object[])
public static List<MetaMethod> respondsTo(Object self, String name)
Returns an object satisfying Groovy truth if the implementing MetaClass responds to a method with the given name regardless of the arguments.
Note that this method's return value is based on realised methods and does not take into account objects or classes that implement invokeMethod or methodMissing
This method is "safe" in that it will always return a value and never throw an exception
self
- The object to inspectname
- The name of the method of interest
MetaObjectProtocol.respondsTo(java.lang.Object, java.lang.String)
public static MetaProperty hasProperty(Object self, String name)
Returns true of the implementing MetaClass has a property of the given name
Note that this method will only return true for realised properties and does not take into account implementation of getProperty or propertyMissing
self
- The object to inspectname
- The name of the property of interest
MetaObjectProtocol.hasProperty(java.lang.Object, java.lang.String)
|
Copyright © 2003-2012 The Codehaus. All rights reserved. | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |