1 package org.apache.lucene.analysis.payloads;
3 * Licensed to the Apache Software Foundation (ASF) under one or more
4 * contributor license agreements. See the NOTICE file distributed with
5 * this work for additional information regarding copyright ownership.
6 * The ASF licenses this file to You under the Apache License, Version 2.0
7 * (the "License"); you may not use this file except in compliance with
8 * the License. You may obtain a copy of the License at
10 * http://www.apache.org/licenses/LICENSE-2.0
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
19 import org.apache.lucene.index.Payload;
20 import org.apache.lucene.util.ArrayUtil;
24 * Encode a character array Integer as a {@link org.apache.lucene.index.Payload}.
26 * See {@link org.apache.lucene.analysis.payloads.PayloadHelper#encodeInt(int, byte[], int)}.
29 public class IntegerEncoder extends AbstractEncoder implements PayloadEncoder {
31 public Payload encode(char[] buffer, int offset, int length) {
32 Payload result = new Payload();
33 int payload = ArrayUtil.parseInt(buffer, offset, length);//TODO: improve this so that we don't have to new Strings
34 byte[] bytes = PayloadHelper.encodeInt(payload);
35 result.setData(bytes);