org.openurp.base.time.Terms Maven / Gradle / Ivy
/*
* OpenURP, Agile University Resource Planning Solution.
*
* Copyright © 2014, The OpenURP Software.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU 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 General Public License
* along with this program. If not, see .
*/
package org.openurp.base.time;
import org.beangle.commons.collection.CollectUtils;
import org.beangle.commons.lang.Numbers;
import org.beangle.commons.lang.Strings;
import java.io.Serializable;
import java.util.Collections;
import java.util.List;
public class Terms implements Serializable, Comparable {
private static final long serialVersionUID = -8846980902784025935L;
public static final Terms Empty = new Terms(0);
private static int valuesOf(String terms) {
if (terms.equals("*") || terms.equals("")) return 0;
int result = 0;
for (String t : Strings.split(terms, ",")) {
if (t.contains("-")) {
int start = Integer.parseInt(Strings.substringBefore(t, "-").trim());
int end = Integer.parseInt(Strings.substringAfter(t, "-").trim());
for (int i = start; i <= end; i++) {
result |= (1 << i);
}
} else {
result |= (1 << Numbers.toInt(t));
}
}
return result;
}
public final int value;
public Terms(int value) {
super();
this.value = value;
}
public Terms(String values) {
this(valuesOf(values));
}
public boolean contains(int term) {
return (value & (1 << term)) > 0;
}
public List getTermList() {
String str = Integer.toBinaryString(value);
List termList = CollectUtils.newArrayList();
if (value > 0) {
for (int i = str.length() - 1; i >= 0; i--) {
if (str.charAt(i) == '1') termList.add(str.length() - i - 1);
}
return termList;
} else {
return Collections.emptyList();
}
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
List terms = getTermList();
for (Integer a : terms) {
sb.append(a).append(',');
}
if (sb.length() > 0) sb.deleteCharAt(sb.length() - 1);
return sb.toString();
}
@Override
public int compareTo(Terms o) {
return this.value - o.value;
}
@Override
public boolean equals(Object obj) {
return ((Terms) obj).value == this.value;
}
@Override
public int hashCode() {
return value;
}
public int getValue() {
return value;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy