1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
/*
* Copyright (c) 2007 innoSysTec (R) GmbH, Germany. All rights reserved.
* Original author: Edmund Wagner
* Creation date: 01.06.2007
*
* Source: $HeadURL$
* Last changed: $LastChangedDate$
*
* the unrar licence applies to all junrar source and binary distributions
* you are not allowed to use this source to re-create the RAR compression algorithm
*
* Here some html entities which can be used for escaping javadoc tags:
* "&": "&" or "&"
* "<": "<" or "<"
* ">": ">" or ">"
* "@": "@"
*/
package com.github.junrar.unpack.ppm;
import com.github.junrar.io.Raw;
/**
* DOCUMENT ME
*
* @author $LastChangedBy$
* @version $LastChangedRevision$
*/
public class State extends Pointer {
public static final int size = 6;
public State(byte[] mem) {
super(mem);
}
public State init(byte[] mem) {
this.mem = mem;
pos = 0;
return this;
}
public int getSymbol() {
return mem[pos]&0xff;
}
public void setSymbol(int symbol) {
mem[pos] = (byte)symbol;
}
public int getFreq() {
return mem[pos+1]&0xff;
}
public void setFreq(int freq) {
mem[pos + 1] = (byte)freq;
}
public void incFreq(int dFreq) {
mem[pos + 1] += dFreq;
}
public int getSuccessor() {
return Raw.readIntLittleEndian(mem, pos+2);
}
public void setSuccessor(PPMContext successor) {
setSuccessor(successor.getAddress());
}
public void setSuccessor(int successor) {
Raw.writeIntLittleEndian(mem, pos + 2, successor);
}
public void setValues(StateRef state){
setSymbol(state.getSymbol());
setFreq(state.getFreq());
setSuccessor(state.getSuccessor());
}
public void setValues(State ptr){
System.arraycopy(ptr.mem, ptr.pos, mem, pos, size);
}
public State decAddress(){
setAddress(pos-size);
return this;
}
public State incAddress(){
setAddress(pos+size);
return this;
}
public static void ppmdSwap(State ptr1, State ptr2) {
byte[] mem1=ptr1.mem, mem2=ptr2.mem;
for (int i=0, pos1=ptr1.pos, pos2=ptr2.pos; i < size; i++, pos1++, pos2++) {
byte temp = mem1[pos1];
mem1[pos1] = mem2[pos2];
mem2[pos2] = temp;
}
}
public String toString() {
StringBuilder buffer = new StringBuilder();
buffer.append("State[");
buffer.append("\n pos=");
buffer.append(pos);
buffer.append("\n size=");
buffer.append(size);
buffer.append("\n symbol=");
buffer.append(getSymbol());
buffer.append("\n freq=");
buffer.append(getFreq());
buffer.append("\n successor=");
buffer.append(getSuccessor());
buffer.append("\n]");
return buffer.toString();
}
}
|