|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.eigenbase.xom.XMLUtil org.eigenbase.xom.XOMUtil mondrian.olap.Util
public class Util
Utility functions used throughout mondrian. All methods are static.
Nested Class Summary | |
---|---|
static class |
Util.ErrorCellValue
|
static class |
Util.PropertyList
PropertyList is an order-preserving list of key-value
pairs. |
Field Summary | |
---|---|
static Object |
EmptyValue
Placeholder which indicates an EMPTY value. |
static int |
JdbcVersion
What version of JDBC? Returns 4 in JDK 1.6 and higher, 3 otherwise. |
static String |
nl
|
static Object |
nullValue
Placeholder which indicates a value NULL. |
static boolean |
PreJdk15
Whether we are running a version of Java before 1.5. |
static boolean |
Retrowoven
Whether the code base has re-engineered using retroweaver. |
Constructor Summary | |
---|---|
Util()
|
Method Summary | ||
---|---|---|
static void |
addDatabaseTime(long millis)
Adds to the cumulative amount of time spent accessing the database. |
|
static List<Member> |
addLevelCalculatedMembers(SchemaReader reader,
Level level,
List<Member> members)
|
|
static
|
areOccurencesEqual(Collection<T> collection)
Returns whether a collection contains precisely one distinct element. |
|
static void |
assertPostcondition(boolean b)
Checks that a postcondition (declared using the javadoc @post tag) is satisfied. |
|
static void |
assertPostcondition(boolean b,
String condition)
Checks that a postcondition (declared using the javadoc @post tag) is satisfied. |
|
static void |
assertPrecondition(boolean b)
Checks that a precondition (declared using the javadoc @pre
tag) is satisfied. |
|
static void |
assertPrecondition(boolean b,
String condition)
Checks that a precondition (declared using the javadoc @pre
tag) is satisfied. |
|
static void |
assertTrue(boolean b)
Throws an internal error if condition is not true. |
|
static void |
assertTrue(boolean b,
String message)
Throws an internal error with the given messagee if condition is not true. |
|
static
|
badValue(Enum<T> anEnum)
Returns an exception indicating that we didn't expect to find this value here. |
|
static String |
camelToUpper(String s)
Converts a camel-case name to an upper-case name with underscores. |
|
static int |
caseSensitiveCompareName(String s,
String t)
Compares two names. |
|
static
|
cast(List<?> list)
Casts a List to a List with a different element type. |
|
static
|
cast(Set<?> set)
Casts a Set to a Set with a different element type. |
|
static void |
checkCJResultLimit(long resultSize)
Check the resultSize against the result limit setting. |
|
static
|
commaList(String s,
List<T> list)
Converts a list of a string. |
|
static int |
compareKey(Object k1,
Object k2)
Returns the result of ((Comparable) k1).compareTo(k2), with special-casing for the fact that Boolean only became comparable in JDK 1.5. |
|
static int |
compareName(String s,
String t)
Compares two names. |
|
static String[] |
convertStackToString(Throwable e)
Converts an error into an array of strings, the most recent error first. |
|
static Exp |
createExpr(OlapElement element)
Converts an olap element (dimension, hierarchy, level or member) into an expression representing a usage of that element in an MDX statement. |
|
static Random |
createRandom(long seed)
Creates a random number generator. |
|
static Validator |
createSimpleValidator(FunTable funTable)
Creates a very simple implementation of Validator . |
|
static UserDefinedFunction |
createUdf(Class<?> udfClass)
Creates a new udf instance from the given udf class. |
|
static long |
dbTimeMillis()
Returns the cumulative amount of time spent accessing the database. |
|
static void |
deprecated(String reason)
Deprecated. |
|
static
|
enumSetAllOf(Class<E> elementType)
Equivalent to EnumSet.allOf(Class) on JDK 1.5 or later. |
|
static
|
enumSetNoneOf(Class<E> elementType)
Equivalent to EnumSet.noneOf(Class) on JDK 1.5 or later. |
|
static
|
enumSetOf(E first,
E... rest)
Equivalent to EnumSet.of(Enum, Enum[]) on JDK 1.5 or
later. |
|
static boolean |
equal(String s,
String t,
boolean matchCase)
Tests two strings for equality, optionally ignoring case. |
|
static boolean |
equalName(String s,
String t)
Returns whether two names are equal. |
|
static boolean |
equals(Object s,
Object t)
Returns true if two objects are equal, or are both null. |
|
static boolean |
equals(String s,
String t)
Returns true if two strings are equal, or are both null. |
|
static
|
getAnnotation(Method method,
String annotationClassName,
T defaultValue)
Returns an annotation of a particular class on a method. |
|
static String |
getErrorMessage(Throwable err)
Constructs the message associated with an arbitrary Java error, making up one based on the stack trace if there is none. |
|
static String |
getErrorMessage(Throwable err,
boolean prependClassName)
Constructs the message associated with an arbitrary Java error, making up one based on the stack trace if there is none. |
|
static Member |
getFirstDescendantOnLevel(SchemaReader reader,
Member parent,
Level level)
returns the first descendant on the level underneath parent. |
|
static int |
getMemberOrdinalInParent(SchemaReader reader,
Member member)
Finds the zero based ordinal of a Member among its siblings. |
|
static int |
hash(int i,
int j)
Combines two integers into a hash code. |
|
static int |
hash(int h,
Object o)
Computes a hash code from an existing hash code and an object (which may be null). |
|
static int |
hashArray(int h,
Object[] a)
Computes a hash code from an existing hash code and an array of objects (which may be null). |
|
static String |
implode(List<Id.Segment> names)
Converts an array of name parts {"part1", "part2"} into a single string "[part1].[part2]". |
|
static boolean |
isEmpty(String s)
Returns whether a string is null or empty. |
|
static boolean |
isNull(Object o)
|
|
static
|
isSorted(List<T> list)
Returns whether a list is strictly sorted. |
|
static boolean |
isValidProperty(Member member,
String propertyName)
Returns whether a property is valid for a given member. |
|
static
|
lookup(Class<E> clazz,
String name)
Looks up an enumeration by name, returning null if not valid. |
|
static
|
lookup(Class<E> clazz,
String name,
E defaultValue)
Looks up an enumeration by name, returning a given default value if not valid. |
|
static OlapElement |
lookup(Query q,
List<Id.Segment> nameParts)
|
|
static Exp |
lookup(Query q,
List<Id.Segment> nameParts,
boolean allowProp)
Converts an identifier into an expression by resolving its parts into an OLAP object (dimension, hierarchy, level or member) within the context of a query. |
|
static OlapElement |
lookupCompound(SchemaReader schemaReader,
OlapElement parent,
List<Id.Segment> names,
boolean failIfNotFound,
int category)
|
|
static OlapElement |
lookupCompound(SchemaReader schemaReader,
OlapElement parent,
List<Id.Segment> names,
boolean failIfNotFound,
int category,
MatchType matchType)
Resolves a name such as '[Products].[Product Department].[Produce]' by resolving the components ('Products', and so forth) one at a time. |
|
(package private) static Cube |
lookupCube(SchemaReader schemaReader,
String cubeName,
boolean fail)
Looks up a cube in a schema reader. |
|
static Level |
lookupHierarchyLevel(Hierarchy hierarchy,
String s)
Finds a named level in this hierarchy. |
|
static Member |
lookupHierarchyRootMember(SchemaReader reader,
Hierarchy hierarchy,
Id.Segment memberName)
|
|
static Member |
lookupHierarchyRootMember(SchemaReader reader,
Hierarchy hierarchy,
Id.Segment memberName,
MatchType matchType)
Finds a root member of a hierarchy with a given name. |
|
protected static Property |
lookupProperty(Level level,
String propertyName)
Finds a member property called propertyName at, or above,
level . |
|
static BigDecimal |
makeBigDecimalFromDouble(double d)
Make a BigDecimal from a double. |
|
static String |
makeFqName(OlapElement parent,
String name)
|
|
static String |
makeFqName(String name)
|
|
static String |
makeFqName(String parentUniqueName,
String name)
|
|
static String |
maskVersion(String str)
Masks Mondrian's version number from a string. |
|
static String |
mdxEncodeString(String st)
Encodes string for MDX (escapes ] as ]] inside a name). |
|
static RuntimeException |
needToImplement(Object o)
Returns an exception which indicates that a particular piece of functionality should work, but a developer has not implemented it yet. |
|
static RuntimeException |
newError(String message)
Creates a non-internal error. |
|
static RuntimeException |
newError(Throwable e,
String message)
Creates a non-internal error. |
|
static RuntimeException |
newInternal(String message)
Creates an internal error with a given message. |
|
static RuntimeException |
newInternal(Throwable e,
String message)
Creates an internal error with a given message and cause. |
|
static long |
nonDbTimeMillis()
Returns the system time less the time spent accessing the database. |
|
static String |
normalizeName(String s)
Generates a normalized form of a name, for use as a key into a map. |
|
static List<String> |
parseCommaList(String nameCommaList)
Parses a comma-separated list. |
|
static Util.PropertyList |
parseConnectString(String s)
Converts an OLE DB connect string into a Util.PropertyList . |
|
static List<Id.Segment> |
parseIdentifier(String s)
|
|
static String |
printMemory()
|
|
static String |
printMemory(String msg)
|
|
static String |
quoteForMdx(String val)
Converts a string into a double-quoted string. |
|
static String |
quoteMdxIdentifier(List<Id.Segment> ids)
Return identifiers quoted in [...].[...]. |
|
static void |
quoteMdxIdentifier(List<Id.Segment> ids,
StringBuilder sb)
|
|
static String |
quoteMdxIdentifier(String id)
Return string quoted in [...]. |
|
static void |
quoteMdxIdentifier(String id,
StringBuilder buf)
|
|
static String |
quotePattern(String s)
Returns a literal pattern String for the specified String. |
|
static String |
readFully(Reader rdr,
int bufferSize)
Read a Reader until EOF and return as String. |
|
static String |
readURL(String urlStr)
Read URL and return String containing content. |
|
static String |
readURL(String urlStr,
Map map)
Returns the contents of a URL, substituting tokens. |
|
static String |
readURL(URL url)
Returns the contents of a URL. |
|
static String |
readURL(URL url,
Map<String,String> map)
Returns the contents of a URL, substituting tokens. |
|
static StringBuilder |
replace(StringBuilder buf,
int start,
String find,
String replace)
Replaces all occurrences of a string in a buffer with another. |
|
static String |
replace(String s,
String find,
String replace)
Returns a string with every occurrence of a seek string replaced with another. |
|
static String |
replaceProperties(String text,
Map<String,String> env)
Replaces tokens in a string. |
|
static String |
singleQuoteString(String val)
Encloses a value in single-quotes, to make a SQL string value. |
|
static void |
singleQuoteString(String val,
StringBuilder buf)
Encloses a value in single-quotes, to make a SQL string value. |
|
static Map<String,String> |
toMap(Properties properties)
|
|
static URL |
toURL(File file)
Creates a file-protocol URL for the given file. |
|
static RuntimeException |
unexpected(Enum value)
Returns an exception indicating that we didn't expect to find this value here. |
|
static
|
union(Collection<? extends T>... collections)
Returns the union of a list of collections. |
|
static
|
union(Iterable<? extends T>... iterables)
Returns the union of a list of iterables. |
|
static String |
uniquify(String name,
int maxLength,
Collection<String> nameList)
Makes a name distinct from other names which have already been used and shorter than a length limit, adds it to the list, and returns it. |
|
static String |
unparse(Exp exp)
Converts an expression to a string. |
|
static String |
unparse(Query query)
Converts an query to a string. |
|
static String |
wildcardToRegexp(List<String> wildcards)
Converts a list of SQL-style patterns into a Java regular expression. |
Methods inherited from class org.eigenbase.xom.XOMUtil |
---|
addAll, addAll, addChild, addChild, addChildren, addElement, concatenate, createDefaultParser, discard, discard, discard, discard, discard, discard, discard, discard, discard, getFirstInstance, toList, toVector, wrapperToXml |
Methods inherited from class org.eigenbase.xom.XMLUtil |
---|
getFirstTagName, printAtt, printAtt, printAtt, printAtt, printPCDATA, printPCDATA, printPCDATA, quoteAtt, quoteAtt, quoteAtt, quoteAtt, quotePCDATA, stringEncodeXML, stringHasXMLSpecials |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
public static final String nl
public static final Object nullValue
public static final Object EmptyValue
public static final boolean PreJdk15
If this variable is true, we will be running retroweaver. Retroweaver
has some problems involving EnumSet
.
public static final int JdbcVersion
public static final boolean Retrowoven
Constructor Detail |
---|
public Util()
Method Detail |
---|
public static boolean isNull(Object o)
public static <T> boolean isSorted(List<T> list)
list
- List
public static String mdxEncodeString(String st)
public static String quoteForMdx(String val)
public static String quoteMdxIdentifier(String id)
public static void quoteMdxIdentifier(String id, StringBuilder buf)
public static String quoteMdxIdentifier(List<Id.Segment> ids)
public static void quoteMdxIdentifier(List<Id.Segment> ids, StringBuilder sb)
public static boolean equals(Object s, Object t)
public static boolean equals(String s, String t)
The result is not affected by
the case sensitive option
; if
you wish to compare names, use equalName(String, String)
.
public static boolean equalName(String s, String t)
case sensitive option
.
Names may be null.
public static boolean equal(String s, String t, boolean matchCase)
s
- First stringt
- Second stringmatchCase
- Whether to perform case-sensitive match
public static int caseSensitiveCompareName(String s, String t)
case
sensitive option
.
Names must not be null.
public static int compareName(String s, String t)
case
sensitive option
.
Names must not be null.
public static String normalizeName(String s)
MondrianProperties.CaseSensitive
is true, the name unchanged
otherwise.
public static int compareKey(Object k1, Object k2)
Comparable.compareTo(T)
public static String replace(String s, String find, String replace)
public static StringBuilder replace(StringBuilder buf, int start, String find, String replace)
buf
- String buffer to act onstart
- Ordinal within find
to start searchingfind
- String to findreplace
- String to replace it with
public static List<Id.Segment> parseIdentifier(String s)
public static String implode(List<Id.Segment> names)
public static String makeFqName(String name)
public static String makeFqName(OlapElement parent, String name)
public static String makeFqName(String parentUniqueName, String name)
public static OlapElement lookupCompound(SchemaReader schemaReader, OlapElement parent, List<Id.Segment> names, boolean failIfNotFound, int category)
public static OlapElement lookupCompound(SchemaReader schemaReader, OlapElement parent, List<Id.Segment> names, boolean failIfNotFound, int category, MatchType matchType)
schemaReader
- Schema reader, supplies access-control contextparent
- Parent element to search innames
- Exploded compound name, such as {"Products",
"Product Department", "Produce"}failIfNotFound
- If the element is not found, determines whether
to return null or throw an errorcategory
- Type of returned element, a Category
value;
Category.Unknown
if it doesn't matter.parseIdentifier(String)
public static OlapElement lookup(Query q, List<Id.Segment> nameParts)
public static Exp lookup(Query q, List<Id.Segment> nameParts, boolean allowProp)
If allowProp
is true, also allows property references
from valid members, for example
[Measures].[Unit Sales].FORMATTED_VALUE
.
In this case, the result will be a ResolvedFunCall
.
q
- Query expression belongs tonameParts
- Parts of the identifierallowProp
- Whether to allow property references
static Cube lookupCube(SchemaReader schemaReader, String cubeName, boolean fail)
cubeName
- Cube namefail
- Whether to fail if not found.
public static Exp createExpr(OlapElement element)
public static Member lookupHierarchyRootMember(SchemaReader reader, Hierarchy hierarchy, Id.Segment memberName)
public static Member lookupHierarchyRootMember(SchemaReader reader, Hierarchy hierarchy, Id.Segment memberName, MatchType matchType)
hierarchy
- memberName
-
public static Level lookupHierarchyLevel(Hierarchy hierarchy, String s)
public static int getMemberOrdinalInParent(SchemaReader reader, Member member)
public static Member getFirstDescendantOnLevel(SchemaReader reader, Member parent, Level level)
public static boolean isEmpty(String s)
public static String singleQuoteString(String val)
singleQuoteForSql(null)
yields NULL
;
singleQuoteForSql("don't")
yields 'don''t'
.
public static void singleQuoteString(String val, StringBuilder buf)
singleQuoteForSql(null)
yields NULL
;
singleQuoteForSql("don't")
yields 'don''t'
.
public static Random createRandom(long seed)
seed
- Seed for random number generator.
If 0, generate a seed from the system clock and print the value
chosen. (This is effectively non-deterministic.)
If -1, generate a seed from an internal random number generator.
(This is deterministic, but ensures that different tests have
different seeds.)
public static boolean isValidProperty(Member member, String propertyName)
member
- MemberpropertyName
- Property name
protected static Property lookupProperty(Level level, String propertyName)
propertyName
at, or above,
level
.
public static void deprecated(String reason)
public static List<Member> addLevelCalculatedMembers(SchemaReader reader, Level level, List<Member> members)
public static RuntimeException needToImplement(Object o)
public static <T extends Enum<T>> RuntimeException badValue(Enum<T> anEnum)
public static String maskVersion(String str)
str
- String
public static String wildcardToRegexp(List<String> wildcards)
For example, {"Foo_", "Bar%BAZ"} becomes "Foo.|Bar.*BAZ".
wildcards
- List of SQL-style wildcard expressions
public static String camelToUpper(String s)
For example, camelToUpper("FooBar")
returns "FOO_BAR".
s
- Camel-case string
public static List<String> parseCommaList(String nameCommaList)
If a value contains a comma, escape it with a second comma. For
example, parseCommaList("x,y,,z")
returns
{"x", "y,z"}
.
nameCommaList
- List of names separated by commas
public static <T> T getAnnotation(Method method, String annotationClassName, T defaultValue)
method
- Method containing annotationannotationClassName
- Name of annotation class to finddefaultValue
- Value to return if annotation is not present
public static <T> String commaList(String s, List<T> list)
commaList("foo", Arrays.asList({"a", "b"}))
returns "foo(a, b)".
s
- Prefixlist
- List
public static <T> Iterable<T> union(Iterable<? extends T>... iterables)
You can use it like this:
Iterable<String> iter1; Iterable<String> iter2; for (String s : union(iter1, iter2)) { print(s); }
iterables
- Array of one or more iterables
public static <T> Iterable<T> union(Collection<? extends T>... collections)
This method exists for code that will be retrowoven to run on JDK 1.4.
Retroweaver has its own version of the Iterable
interface, which
is problematic since the Collection
classes don't implement it.
This method solves some of these problems by working in terms of
collections; retroweaver deals with these correctly.
collections
- Array of one or more collections
union(Iterable[])
public static String uniquify(String name, int maxLength, Collection<String> nameList)
name
- Suggested name, may not be uniquemaxLength
- Maximum length of generated namenameList
- Collection of names already used
public static <T> boolean areOccurencesEqual(Collection<T> collection)
collection
- Collection
public static void assertTrue(boolean b)
assert
, but that is a keyword as of JDK 1.4.
public static void assertTrue(boolean b, String message)
assert
, but that is a keyword as
of JDK 1.4.
public static RuntimeException newInternal(String message)
public static RuntimeException newInternal(Throwable e, String message)
public static RuntimeException newError(String message)
public static RuntimeException newError(Throwable e, String message)
public static RuntimeException unexpected(Enum value)
value
- Valuepublic static void assertPrecondition(boolean b)
@pre
tag) is satisfied.
b
- The value of executing the conditionpublic static void assertPrecondition(boolean b, String condition)
@pre
tag) is satisfied. For example,
void f(String s) { Util.assertPrecondition(s != null, "s != null"); ... }
b
- The value of executing the conditioncondition
- The text of the conditionpublic static void assertPostcondition(boolean b)
@post
tag) is satisfied.
b
- The value of executing the conditionpublic static void assertPostcondition(boolean b, String condition)
@post
tag) is satisfied.
b
- The value of executing the conditionpublic static String[] convertStackToString(Throwable e)
e
- the error; may be null. Errors are chained according to their
cause
.public static String getErrorMessage(Throwable err)
getErrorMessage(Throwable,boolean)
, but does not print the
class name if the exception is derived from SQLException
or is exactly a Exception
.
public static String getErrorMessage(Throwable err, boolean prependClassName)
err
- the errorprependClassName
- should the error be preceded by the
class name of the Java exception? defaults to false, unless the error
is derived from SQLException
or is exactly a Exception
public static String unparse(Exp exp)
public static String unparse(Query query)
public static URL toURL(File file) throws MalformedURLException
MalformedURLException
public static Util.PropertyList parseConnectString(String s)
Util.PropertyList
.
For example, "Provider=MSOLAP; DataSource=LOCALHOST;"
becomes the set of (key, value) pairs {("Provider","MSOLAP"),
("DataSource", "LOCALHOST")}
. Another example is
Provider='sqloledb';Data Source='MySqlServer';Initial
Catalog='Pubs';Integrated Security='SSPI';
.
This method implements as much as possible of the OLE DB connect string syntax
specification. To find what it actually does, take
a look at the mondrian.olap.UtilTestCase
test case.
public static int hash(int i, int j)
public static int hash(int h, Object o)
public static int hashArray(int h, Object[] a)
public static long dbTimeMillis()
public static void addDatabaseTime(long millis)
public static long nonDbTimeMillis()
public static Validator createSimpleValidator(FunTable funTable)
Validator
. (Only
useful for resolving trivial expressions.)
public static String readFully(Reader rdr, int bufferSize) throws IOException
IOException
rdr
- Reader to Read.bufferSize
- size of buffer to allocate for reading.
public static String readURL(String urlStr) throws MalformedURLException, IOException
MalformedURLException
IOException
urlStr
- actually a catalog URL
public static String readURL(String urlStr, Map map) throws MalformedURLException, IOException
Replaces the tokens "${key}" if "key" occurs in the key-value map.
MalformedURLException
IOException
urlStr
- URL stringmap
- Key/value map
public static String readURL(URL url) throws IOException
IOException
url
- URL
public static String readURL(URL url, Map<String,String> map) throws IOException
Replaces the tokens "${key}" if "key" occurs in the key-value map.
IOException
url
- URLmap
- Key/value map
public static Map<String,String> toMap(Properties properties)
public static String replaceProperties(String text, Map<String,String> env)
Replaces the tokens "${key}" if "key" occurs in the key-value map. Otherwise "${key}" is left in the string unchanged.
text
- Source stringenv
- Map of key-value pairs
public static String printMemory()
public static String printMemory(String msg)
public static <T> Set<T> cast(Set<?> set)
set
- Set
public static <T> List<T> cast(List<?> list)
list
- List
public static <E extends Enum<E>> E lookup(Class<E> clazz, String name)
public static <E extends Enum<E>> E lookup(Class<E> clazz, String name, E defaultValue)
public static <E extends Enum<E>> Set<E> enumSetOf(E first, E... rest)
EnumSet.of(Enum, Enum[])
on JDK 1.5 or
later. Otherwise, returns an ordinary set.
NullPointerException
- if any of the specified elements are null,
or if rest is nullfirst
- an element that the set is to contain initiallyrest
- the remaining elements the set is to contain initially
public static <E extends Enum<E>> Set<E> enumSetNoneOf(Class<E> elementType)
EnumSet.noneOf(Class)
on JDK 1.5 or later.
Otherwise, returns an ordinary set.
elementType
- the class object of the element type for this enum
setpublic static <E extends Enum<E>> Set<E> enumSetAllOf(Class<E> elementType)
EnumSet.allOf(Class)
on JDK 1.5 or later.
Otherwise, returns an ordinary set.
elementType
- the class object of the element type for this enum
setpublic static BigDecimal makeBigDecimalFromDouble(double d)
d
- the input double
public static String quotePattern(String s)
Specification as for Pattern.quote(String)
, which was
introduced in JDK 1.5.
s
- The string to be literalized
public static UserDefinedFunction createUdf(Class<?> udfClass)
udfClass
- the class to create new instance for
public static void checkCJResultLimit(long resultSize)
ResourceLimitExceededException
resultSize
-
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |