mirror of https://github.com/apache/lucene.git
LUCENE-1564: don't let Field.setValue switch between binary & non-binary fields
git-svn-id: https://svn.apache.org/repos/asf/lucene/java/trunk@754789 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
36329624f9
commit
904b7967c1
|
@ -207,16 +207,28 @@ public final class Field extends AbstractField implements Fieldable, Serializabl
|
||||||
* href="http://wiki.apache.org/lucene-java/ImproveIndexingSpeed">ImproveIndexingSpeed</a>
|
* href="http://wiki.apache.org/lucene-java/ImproveIndexingSpeed">ImproveIndexingSpeed</a>
|
||||||
* for details.</p> */
|
* for details.</p> */
|
||||||
public void setValue(String value) {
|
public void setValue(String value) {
|
||||||
|
if (isBinary) {
|
||||||
|
throw new IllegalArgumentException("cannot set a String value on a binary field");
|
||||||
|
}
|
||||||
fieldsData = value;
|
fieldsData = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Expert: change the value of this field. See <a href="#setValue(java.lang.String)">setValue(String)</a>. */
|
/** Expert: change the value of this field. See <a href="#setValue(java.lang.String)">setValue(String)</a>. */
|
||||||
public void setValue(Reader value) {
|
public void setValue(Reader value) {
|
||||||
|
if (isBinary) {
|
||||||
|
throw new IllegalArgumentException("cannot set a Reader value on a binary field");
|
||||||
|
}
|
||||||
|
if (isStored) {
|
||||||
|
throw new IllegalArgumentException("cannot set a Reader value on a stored field");
|
||||||
|
}
|
||||||
fieldsData = value;
|
fieldsData = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Expert: change the value of this field. See <a href="#setValue(java.lang.String)">setValue(String)</a>. */
|
/** Expert: change the value of this field. See <a href="#setValue(java.lang.String)">setValue(String)</a>. */
|
||||||
public void setValue(byte[] value) {
|
public void setValue(byte[] value) {
|
||||||
|
if (!isBinary) {
|
||||||
|
throw new IllegalArgumentException("cannot set a byte[] value on a non-binary field");
|
||||||
|
}
|
||||||
fieldsData = value;
|
fieldsData = value;
|
||||||
binaryLength = value.length;
|
binaryLength = value.length;
|
||||||
binaryOffset = 0;
|
binaryOffset = 0;
|
||||||
|
@ -224,6 +236,9 @@ public final class Field extends AbstractField implements Fieldable, Serializabl
|
||||||
|
|
||||||
/** Expert: change the value of this field. See <a href="#setValue(java.lang.String)">setValue(String)</a>. */
|
/** Expert: change the value of this field. See <a href="#setValue(java.lang.String)">setValue(String)</a>. */
|
||||||
public void setValue(byte[] value, int offset, int length) {
|
public void setValue(byte[] value, int offset, int length) {
|
||||||
|
if (!isBinary) {
|
||||||
|
throw new IllegalArgumentException("cannot set a byte[] value on a non-binary field");
|
||||||
|
}
|
||||||
fieldsData = value;
|
fieldsData = value;
|
||||||
binaryLength = length;
|
binaryLength = length;
|
||||||
binaryOffset = offset;
|
binaryOffset = offset;
|
||||||
|
@ -232,6 +247,12 @@ public final class Field extends AbstractField implements Fieldable, Serializabl
|
||||||
|
|
||||||
/** Expert: change the value of this field. See <a href="#setValue(java.lang.String)">setValue(String)</a>. */
|
/** Expert: change the value of this field. See <a href="#setValue(java.lang.String)">setValue(String)</a>. */
|
||||||
public void setValue(TokenStream value) {
|
public void setValue(TokenStream value) {
|
||||||
|
if (isBinary) {
|
||||||
|
throw new IllegalArgumentException("cannot set a TokenStream value on a binary field");
|
||||||
|
}
|
||||||
|
if (isStored) {
|
||||||
|
throw new IllegalArgumentException("cannot set a TokenStream value on a stored field");
|
||||||
|
}
|
||||||
fieldsData = value;
|
fieldsData = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -260,4 +260,23 @@ public class TestDocument extends LuceneTestCase
|
||||||
dir.close();
|
dir.close();
|
||||||
assertEquals("did not see all IDs", 7, result);
|
assertEquals("did not see all IDs", 7, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testFieldSetValueChangeBinary() {
|
||||||
|
Field field1 = new Field("field1", new byte[0],
|
||||||
|
Field.Store.YES);
|
||||||
|
Field field2 = new Field("field2", "",
|
||||||
|
Field.Store.YES, Field.Index.ANALYZED);
|
||||||
|
try {
|
||||||
|
field1.setValue("abc");
|
||||||
|
fail("did not hit expected exception");
|
||||||
|
} catch (IllegalArgumentException iae) {
|
||||||
|
// expected
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
field2.setValue(new byte[0]);
|
||||||
|
fail("did not hit expected exception");
|
||||||
|
} catch (IllegalArgumentException iae) {
|
||||||
|
// expected
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue