Skip to content

Commit aeecc94

Browse files
Merge branch '27-unsigned' into release-3.0.0-alpha2
2 parents 9f6b237 + 85e4613 commit aeecc94

File tree

2 files changed

+37
-2
lines changed

2 files changed

+37
-2
lines changed
Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,34 @@
1+
/*
2+
* Copyright 2019 ObjectBox Ltd. All rights reserved.
3+
*
4+
* Licensed under the Apache License, Version 2.0 (the "License");
5+
* you may not use this file except in compliance with the License.
6+
* You may obtain a copy of the License at
7+
*
8+
* http://www.apache.org/licenses/LICENSE-2.0
9+
*
10+
* Unless required by applicable law or agreed to in writing, software
11+
* distributed under the License is distributed on an "AS IS" BASIS,
12+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
* See the License for the specific language governing permissions and
14+
* limitations under the License.
15+
*/
16+
17+
package io.objectbox.annotation;
18+
19+
import java.lang.annotation.ElementType;
20+
import java.lang.annotation.Retention;
21+
import java.lang.annotation.RetentionPolicy;
22+
import java.lang.annotation.Target;
23+
24+
/**
25+
* Indicates that values of an integer property (e.g. int and long in Java)
26+
* should be treated as unsigned when doing queries or creating indexes.
27+
* <p>
28+
* For example consider a set of integers sorted by the default order: [-2, -1, 0, 1, 2].
29+
* If all values are treated as unsigned, the order would be [0, 1, 2, -2, -1] instead.
30+
*/
31+
@Retention(RetentionPolicy.CLASS)
32+
@Target(ElementType.FIELD)
33+
public @interface Unsigned {
34+
}

objectbox-java/src/main/java/io/objectbox/model/PropertyFlags.java

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -77,8 +77,9 @@ private PropertyFlags() { }
7777
*/
7878
public static final int INDEX_HASH64 = 4096;
7979
/**
80-
* Unused yet: While our default are signed ints, queries and indexes need do know signing info.
81-
* Note: Don't combine with ID (IDs are always unsigned internally).
80+
* In Java (and Kotlin) integers are stored as signed by default,
81+
* but queries and indexes may choose to treat them as unsigned when using this flag.
82+
* Note: Don't combine with ID, they are always unsigned internally.
8283
*/
8384
public static final int UNSIGNED = 8192;
8485
}

0 commit comments

Comments
 (0)