X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.databoard%2Fsrc%2Forg%2Fsimantics%2Fdataboard%2Ftype%2FStringType.java;h=f54bf8abc7c8158385f3c127a05b8171e3b36e0e;hb=refs%2Fchanges%2F38%2F238%2F2;hp=db74bbfa17dadd4db0e533942e2ecba4036b2df1;hpb=24e2b34260f219f0d1644ca7a138894980e25b14;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.databoard/src/org/simantics/databoard/type/StringType.java b/bundles/org.simantics.databoard/src/org/simantics/databoard/type/StringType.java index db74bbfa1..f54bf8abc 100644 --- a/bundles/org.simantics.databoard/src/org/simantics/databoard/type/StringType.java +++ b/bundles/org.simantics.databoard/src/org/simantics/databoard/type/StringType.java @@ -1,78 +1,78 @@ -/******************************************************************************* - * Copyright (c) 2010 Association for Decentralized Information Management in - * Industry THTH ry. - * All rights reserved. This program and the accompanying materials - * are made available under the terms of the Eclipse Public License v1.0 - * which accompanies this distribution, and is available at - * http://www.eclipse.org/legal/epl-v10.html - * - * Contributors: - * VTT Technical Research Centre of Finland - initial API and implementation - *******************************************************************************/ +/******************************************************************************* + * Copyright (c) 2010 Association for Decentralized Information Management in + * Industry THTH ry. + * All rights reserved. This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v1.0 + * which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v10.html + * + * Contributors: + * VTT Technical Research Centre of Finland - initial API and implementation + *******************************************************************************/ package org.simantics.databoard.type; -import java.util.Set; -import java.util.regex.Pattern; -import java.util.regex.PatternSyntaxException; - -import org.simantics.databoard.accessor.error.ReferenceException; -import org.simantics.databoard.accessor.reference.ChildReference; -import org.simantics.databoard.util.IdentityPair; -import org.simantics.databoard.util.Limit; -import org.simantics.databoard.util.Range; -import org.simantics.databoard.util.RangeException; +import java.util.Set; +import java.util.regex.Pattern; +import java.util.regex.PatternSyntaxException; + +import org.simantics.databoard.accessor.error.ReferenceException; +import org.simantics.databoard.accessor.reference.ChildReference; +import org.simantics.databoard.util.IdentityPair; +import org.simantics.databoard.util.Limit; +import org.simantics.databoard.util.Range; +import org.simantics.databoard.util.RangeException; public class StringType extends Datatype { - - public static final String KEY_PATTERN = "pattern"; - public static final String KEY_MIMETYPE = "mimeType"; - public static final String KEY_LENGTH = "length"; + + public static final String KEY_PATTERN = "pattern"; + public static final String KEY_MIMETYPE = "mimeType"; + public static final String KEY_LENGTH = "length"; - private transient Range _length; + private transient Range _length; private transient String _lengthIsForStr; - private transient Pattern pattern_; + private transient Pattern pattern_; private transient String pattern_IsForStr; public StringType () {} - public StringType (String pattern) { - setPattern(pattern); + public StringType (String pattern) { + setPattern(pattern); } public StringType (String pattern, String mimeType, Range length) { - setPattern(pattern); - setMimeType(mimeType); + setPattern(pattern); + setMimeType(mimeType); setLength(length); } public StringType (String pattern, String mimeType, String length) { - setPattern(pattern); - setMimeType(mimeType); - setLength(length); - } - - @Override - public int getComponentCount() { - return 0; - } - - @Override - public Datatype getComponentType(int index) { - throw new IllegalArgumentException(); - } - - @Override - public Datatype getComponentType(ChildReference path) { - if (path==null) return this; - throw new IllegalArgumentException(); + setPattern(pattern); + setMimeType(mimeType); + setLength(length); + } + + @Override + public int getComponentCount() { + return 0; + } + + @Override + public Datatype getComponentType(int index) { + throw new IllegalArgumentException(); + } + + @Override + public Datatype getComponentType(ChildReference path) { + if (path==null) return this; + throw new IllegalArgumentException(); } @Override protected boolean deepEquals(Object obj, Set> compareHistory) { - if (this==obj) return true; - if ( !hasEqualMetadata(obj) ) return false; + if (this==obj) return true; + if ( !hasEqualMetadata(obj) ) return false; return obj instanceof StringType; - } + } @Override public int hashCode() { @@ -95,31 +95,31 @@ public class StringType extends Datatype { public void setPattern(String pattern) throws PatternSyntaxException - { - if ( pattern == null ) metadata.remove(KEY_PATTERN); else - metadata.put(KEY_PATTERN, pattern); + { + if ( pattern == null ) metadata.remove(KEY_PATTERN); else + metadata.put(KEY_PATTERN, pattern); } - public String getMimeType() { + public String getMimeType() { return metadata.get(KEY_MIMETYPE); } - public void setMimeType(String mimeType) { + public void setMimeType(String mimeType) { if (mimeType==null) metadata.remove( KEY_MIMETYPE ); else - metadata.put(KEY_MIMETYPE, mimeType); + metadata.put(KEY_MIMETYPE, mimeType); } - public Range getLength() { - String lengthStr = metadata.get( KEY_LENGTH ); - if ( lengthStr == null ) return null; - if ( lengthStr == _lengthIsForStr ) return _length; - try { - _lengthIsForStr = lengthStr; - _length = Range.valueOf( lengthStr ); - } catch (RangeException e) { - _length = null; + public Range getLength() { + String lengthStr = metadata.get( KEY_LENGTH ); + if ( lengthStr == null ) return null; + if ( lengthStr == _lengthIsForStr ) return _length; + try { + _lengthIsForStr = lengthStr; + _length = Range.valueOf( lengthStr ); + } catch (RangeException e) { + _length = null; } - return _length; + return _length; } public int minLength() { @@ -145,42 +145,42 @@ public class StringType extends Datatype { */ public Pattern getCompiledPattern() { - String patternStr = metadata.get( KEY_PATTERN ); - if ( patternStr == null ) return null; - if ( patternStr == pattern_IsForStr ) return pattern_; - try { - pattern_IsForStr = patternStr; - pattern_ = Pattern.compile(patternStr); - } catch (PatternSyntaxException e) { - pattern_ = null; - } - return pattern_; + String patternStr = metadata.get( KEY_PATTERN ); + if ( patternStr == null ) return null; + if ( patternStr == pattern_IsForStr ) return pattern_; + try { + pattern_IsForStr = patternStr; + pattern_ = Pattern.compile(patternStr); + } catch (PatternSyntaxException e) { + pattern_ = null; + } + return pattern_; } - public void setLength(String length) { - if ( length == null ) metadata.remove( KEY_LENGTH ); else + public void setLength(String length) { + if ( length == null ) metadata.remove( KEY_LENGTH ); else metadata.put( KEY_LENGTH, length ); } public void setLength(Range range) { - if (range == null) { - this._length = null; - this._lengthIsForStr = null; - metadata.remove( KEY_LENGTH ); - } else { - this._length = range; - this._lengthIsForStr = range.toString(); - metadata.put( KEY_LENGTH, _lengthIsForStr ); - } - } - - @SuppressWarnings("unchecked") - @Override - public T getChildType(ChildReference reference) throws ReferenceException { - if (reference==null) return (T) this; - throw new ReferenceException(reference.getClass()+" is not a subreference of StringType"); - } - + if (range == null) { + this._length = null; + this._lengthIsForStr = null; + metadata.remove( KEY_LENGTH ); + } else { + this._length = range; + this._lengthIsForStr = range.toString(); + metadata.put( KEY_LENGTH, _lengthIsForStr ); + } + } + + @SuppressWarnings("unchecked") + @Override + public T getChildType(ChildReference reference) throws ReferenceException { + if (reference==null) return (T) this; + throw new ReferenceException(reference.getClass()+" is not a subreference of StringType"); + } + }