
org.marre.sms.SmsDcs Maven / Gradle / Ivy
/* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is "SMS Library for the Java platform".
*
* The Initial Developer of the Original Code is Markus Eriksson.
* Portions created by the Initial Developer are Copyright (C) 2002
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ***** */
package org.marre.sms;
import java.io.Serializable;
/**
* Represents a SMS DCS (Data Coding Scheme).
*
* @version $Id$
* @author Markus Eriksson
*/
public class SmsDcs implements Serializable {
/**
*
*/
private static final long serialVersionUID = -5797340786616956L;
/** The encoded dcs. */
protected final byte dcs_;
/**
* Creates a specific DCS.
*
* @param dcs
* The dcs.
*/
public SmsDcs(byte dcs) {
dcs_ = dcs;
}
/**
* Returns the encoded dcs.
*
* @return The dcs.
*/
public byte getValue() {
return dcs_;
}
/**
* Builds a general-data-coding dcs.
*
* @param alphabet
* The alphabet.
* @param messageClass
* The message class.
*
* @return A valid general data coding DCS.
*/
public static SmsDcs getGeneralDataCodingDcs(SmsAlphabet alphabet, SmsMsgClass messageClass) {
byte dcs = 0x00;
// Bits 3 and 2 indicate the alphabet being used, as follows :
// Bit3 Bit2 Alphabet:
// 0 0 Default alphabet
// 0 1 8 bit data
// 1 0 UCS2 (16bit) [10]
// 1 1 Reserved
switch (alphabet) {
case ASCII:
case GSM:
dcs |= 0x00;
break;
case LATIN1:
dcs |= 0x04;
break;
case UCS2:
dcs |= 0x08;
break;
case RESERVED:
dcs |= 0x0C;
break;
}
switch (messageClass) {
case CLASS_0:
dcs |= 0x10;
break;
case CLASS_1:
dcs |= 0x11;
break;
case CLASS_2:
dcs |= 0x12;
break;
case CLASS_3:
dcs |= 0x13;
break;
case CLASS_UNKNOWN:
dcs |= 0x00;
break;
}
return new SmsDcs(dcs);
}
/**
* Decodes the given dcs and returns the alphabet.
*
* @return Returns the alphabet or NULL if it was not possible to find an
* alphabet for this dcs.
*/
public SmsAlphabet getAlphabet() {
switch (getGroup()) {
case GENERAL_DATA_CODING:
case MSG_MARK_AUTO_DELETE:
case MESSAGE_WAITING_DISCARD:
// General Data Coding Indication
if (dcs_ == 0x00) {
return SmsAlphabet.ASCII;
}
switch (dcs_ & 0x0C) {
case 0x00:
return SmsAlphabet.ASCII;
case 0x04:
return SmsAlphabet.LATIN1;
case 0x08:
return SmsAlphabet.UCS2;
case 0x0C:
return SmsAlphabet.RESERVED;
default:
return SmsAlphabet.UCS2;
}
case MESSAGE_WAITING_STORE_GSM:
return SmsAlphabet.ASCII;
case MESSAGE_WAITING_STORE_UCS2:
return SmsAlphabet.UCS2;
case DATA_CODING_MESSAGE:
switch (dcs_ & 0x04) {
case 0x00:
return SmsAlphabet.ASCII;
case 0x04:
return SmsAlphabet.LATIN1;
default:
return SmsAlphabet.UCS2;
}
default:
return SmsAlphabet.UCS2;
}
}
/**
* What group (type of message) is the given dcs.
*
* @return The matching group. Or null if unknown.
*/
public DcsGroup getGroup() {
switch ((dcs_ & 0xC0)) {
case 0x00:
return DcsGroup.GENERAL_DATA_CODING;
case 0x40:
return DcsGroup.MSG_MARK_AUTO_DELETE;
case 0x80:
return DcsGroup.RESERVED;
}
switch ((dcs_ & 0xF0)) {
case 0xC0:
return DcsGroup.MESSAGE_WAITING_DISCARD;
case 0xD0:
return DcsGroup.MESSAGE_WAITING_STORE_GSM;
case 0xE0:
return DcsGroup.MESSAGE_WAITING_STORE_UCS2;
case 0xF0:
return DcsGroup.DATA_CODING_MESSAGE;
default:
return DcsGroup.GENERAL_DATA_CODING;
}
}
/**
* Get the message class.
*
* @return Returns the message class.
*/
public SmsMsgClass getMessageClass() {
switch (getGroup()) {
case GENERAL_DATA_CODING:
// General Data Coding Indication
if (dcs_ == 0x00) {
return SmsMsgClass.CLASS_UNKNOWN;
}
switch (dcs_ & 0x13) {
case 0x10:
return SmsMsgClass.CLASS_0;
case 0x11:
return SmsMsgClass.CLASS_1;
case 0x12:
return SmsMsgClass.CLASS_2;
case 0x13:
return SmsMsgClass.CLASS_3;
default:
return SmsMsgClass.CLASS_UNKNOWN;
}
case DATA_CODING_MESSAGE:
// Data coding/message class
switch (dcs_ & 0x03) {
case 0x00:
return SmsMsgClass.CLASS_0;
case 0x01:
return SmsMsgClass.CLASS_1;
case 0x02:
return SmsMsgClass.CLASS_2;
case 0x03:
return SmsMsgClass.CLASS_3;
default:
return SmsMsgClass.CLASS_UNKNOWN;
}
default:
return SmsMsgClass.CLASS_UNKNOWN;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy