org.rapidoidx.data.KeyValueRanges Maven / Gradle / Ivy
package org.rapidoidx.data;
/*
* #%L
* rapidoid-x-buffer
* %%
* Copyright (C) 2014 - 2015 Nikolche Mihajlovski and contributors
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see .
* #L%
*/
import java.util.Map;
import org.rapidoid.annotation.Authors;
import org.rapidoid.annotation.Since;
import org.rapidoid.util.U;
import org.rapidoid.util.UTILS;
import org.rapidoidx.buffer.Buf;
import org.rapidoidx.bytes.BytesUtil;
@Authors("Nikolche Mihajlovski")
@Since("3.0.0")
public class KeyValueRanges {
public final Range[] keys;
public final Range[] values;
public int count;
public KeyValueRanges(int capacity) {
this.keys = new Range[capacity];
this.values = new Range[capacity];
for (int i = 0; i < capacity; i++) {
keys[i] = new Range();
values[i] = new Range();
keys[i].reset();
values[i].reset();
}
}
public void reset() {
for (int i = 0; i < count; i++) {
keys[i].reset();
values[i].reset();
}
count = 0;
}
public Range get(Buf buf, byte[] key, boolean caseSensitive) {
for (int i = 0; i < count; i++) {
if (BytesUtil.matches(buf.bytes(), keys[i], key, caseSensitive)) {
return values[i];
}
}
return null;
}
@Override
public String toString() {
return super.toString() + "[" + count + "]";
}
public int max() {
return keys.length;
}
public String str(Buf src) {
StringBuilder sb = new StringBuilder();
sb.append("[");
for (int i = 0; i < count; i++) {
if (i > 0) {
sb.append(", ");
}
sb.append("<");
sb.append(keys[i].str(src.bytes()));
sb.append(":=");
sb.append(values[i].str(src.bytes()));
sb.append(">");
}
sb.append("]");
return sb.toString();
}
public int add() {
if (count >= max()) {
throw U.rte("too many key-values!");
}
return count++;
}
public Map toMap(String data) {
Map map = U.map();
for (int i = 0; i < count; i++) {
map.put(keys[i].get(data), values[i].get(data));
}
return map;
}
public Map toMap(Buf src, boolean urlDecodeKeys, boolean urlDecodeVals) {
Map map = U.map();
for (int i = 0; i < count; i++) {
String key = keys[i].str(src.bytes());
String val = values[i].str(src.bytes());
if (urlDecodeKeys) {
key = UTILS.urlDecode(key);
}
if (urlDecodeVals) {
val = UTILS.urlDecode(val);
}
map.put(key, val);
}
return map;
}
public Map toBinaryMap(Buf src, boolean urlDecodeKeys) {
Map map = U.map();
for (int i = 0; i < count; i++) {
String key = keys[i].str(src.bytes());
byte[] val = values[i].bytes(src);
if (urlDecodeKeys) {
key = UTILS.urlDecode(key);
}
map.put(key, val);
}
return map;
}
}