org.jclarion.clarion.ClarionAsciiFile Maven / Gradle / Ivy
/**
* Copyright 2010, by Andrew Barnham
*
* The contents of this file are subject to
* GNU Lesser General Public License (LGPL), v.3
* http://www.gnu.org/licenses/lgpl.txt
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied.
*/
package org.jclarion.clarion;
import java.io.IOException;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.jclarion.clarion.constants.Prop;
import org.jclarion.clarion.file.ClarionFileFactory;
import org.jclarion.clarion.runtime.CErrorImpl;
import org.jclarion.clarion.runtime.CFile;
import org.jclarion.clarion.util.SharedWriter;
public class ClarionAsciiFile extends ClarionFile
{
private ClarionRandomAccessCharFile file;
private SharedWriter stream;
private boolean clip=true;
private char endOfRecord[] = new char[] { (byte)'\r', (byte)'\n' };
private int tab=8;
private int position;
@Override
public void add() {
CErrorImpl.getInstance().clearError();
if (file==null) {
CErrorImpl.getInstance().setError(37,"File not open");
}
try {
write(file.length(),-1);
} catch (IOException ex) {
CErrorImpl.getInstance().setError(05,ex.getMessage());
}
}
private void serializeToStream()
{
stream.reset();
try {
int count = getVariableCount();
for (int fscan=1;fscan<=count;fscan++) {
ClarionObject co = flatWhat(fscan);
String content = co.toString();
int len = co.getSize();
if (len==-1) {
if (fscan len) {
stream.write(content, 0, len);
} else {
stream.write(content);
for (int scan = content.length(); scan < len; scan++) {
stream.write(' ');
}
}
}
} catch (IOException ex) { }
}
private void copyStreamToRecord()
{
if (stream.getSize()==0) {
CErrorImpl.getInstance().setError(33,"File not found");
return;
}
stream.shrink(endOfRecord);
int stream_pos=0;
int stream_len = stream.getSize();
char stream_data[]=stream.getBuffer();
int count = getVariableCount();
for (int fscan=1;fscan<=count;fscan++) {
ClarionObject co = flatWhat(fscan);
int len = co.getSize();
if (len==-1) {
if (fscan stream_len) {
len = stream_len - stream_pos;
}
co.setValue(new String(stream_data, stream_pos, len));
stream_pos += len;
}
}
private void write(long pos,int len)
{
try {
preserveRead();
file.seek(pos);
serializeToStream();
if (len>=0) {
while (stream.getSize()=0 && len0 && buffer[size-1]==' ') {
size--;
}
}
file.write(buffer,0,size);
file.write(this.endOfRecord,0,this.endOfRecord.length);
} catch (IOException ex) {
CErrorImpl.getInstance().setError(05,ex.getMessage());
}
}
@Override
public void add(int size) {
CErrorImpl.getInstance().clearError();
if (file==null) {
CErrorImpl.getInstance().setError(37,"File not open");
}
try {
write(file.length(),size);
} catch (IOException ex) {
CErrorImpl.getInstance().setError(05,ex.getMessage());
}
}
@Override
public boolean bof() {
throw new RuntimeException("Not supported");
}
@Override
public void buffer(Integer pagesize, Integer behind, Integer ahead,
Integer timeout)
{
}
@Override
public void build()
{
}
@Override
public void close() {
if (file!=null) {
try {
file.close();
} catch (IOException e) {
e.printStackTrace();
}
file=null;
}
}
@Override
public void create() {
String fname=getProperty(Prop.NAME).toString().trim();
CErrorImpl.getInstance().clearError();
if (!Boolean.TRUE.equals(ClarionFileFactory.getInstance().create(fname))) {
CErrorImpl.getInstance().setError(5,"Could not create");
}
}
@Override
public void delete()
{
throw new RuntimeException("Not supported");
}
@Override
public boolean eof()
{
if (file==null) return true;
try {
return readPosition()==file.length();
} catch (IOException e) {
return true;
}
}
@Override
public void flush()
{
}
@Override
public void freeState(int state)
{
throw new RuntimeException("Not supported");
}
@Override
public void get(ClarionKey akey)
{
throw new RuntimeException("Not supported");
}
@Override
public void get(ClarionString pointer, Integer len)
{
if (len!=null) {
throw new RuntimeException("Not supported");
}
reget(pointer);
}
@Override
public void get(ClarionNumber position, Integer len) {
if (len!=null) {
throw new RuntimeException("Not supported");
}
CErrorImpl.getInstance().clearError();
get(position.intValue()-1);
}
@Override
public ClarionString getNulls()
{
throw new RuntimeException("Not supported");
}
@Override
public int getPointer()
{
return (int)(position)+1;
}
@Override
public ClarionString getPosition(ClarionKey key)
{
if (key!=null) {
throw new RuntimeException("Not supported");
}
char bits[] = new char[4];
int pointer = getPointer();
bits[0]=(char)((pointer>>24)&0xff);
bits[1]=(char)((pointer>>16)&0xff);
bits[2]=(char)((pointer>>8)&0xff);
bits[3]=(char)((pointer)&0xff);
return new ClarionString(new String(bits));
}
@Override
public int getState()
{
throw new RuntimeException("Not supported");
}
@Override
public void lock()
{
throw new RuntimeException("Not supported");
}
private boolean appendToStream(char next_byte)
{
if (next_byte== '\t') {
if (tab>0) {
stream.write(' ');
while ( (stream.getSize()%tab) !=0 ) {
stream.write(' ');
}
} else if (tab==-100) {
stream.write('\t');
} else if (tab<0) {
for (int scan=0;scan<-tab;scan++) {
stream.write(' ');
}
}
} else {
stream.write(next_byte);
}
return (next_byte==endOfRecord[endOfRecord.length-1]);
}
@Override
public void next()
{
CErrorImpl.getInstance().clearError();
if (file==null) {
CErrorImpl.getInstance().setError(37,"File not open");
return;
}
stream.reset();
try {
position = readPosition();
while ( true ) {
int read = read();
if (read==-1) break;
if (appendToStream( (char)read )) break;
}
copyStreamToRecord();
} catch (IOException ex) {
CErrorImpl.getInstance().setError(33,ex.getMessage());
return;
}
}
@Override
public void open(int mode)
{
String fname=getProperty(Prop.NAME).toString().trim();
try {
file=ClarionFileFactory.getInstance().getRandomAccessFile(fname).getCharFile();
CErrorImpl.getInstance().clearError();
} catch (IOException e) {
e.printStackTrace();
CErrorImpl.getInstance().setError(2,e.getMessage());
}
stream=new SharedWriter();
}
@Override
public void previous()
{
throw new RuntimeException("Not supported");
}
@Override
public void put()
{
CErrorImpl.getInstance().clearError();
if (file==null) {
CErrorImpl.getInstance().setError(37,"File not open");
}
write(position,-1);
}
@Override
public int records()
{
throw new RuntimeException("Not supported");
}
@Override
public void reget(ClarionKey key,ClarionString string)
{
CErrorImpl.getInstance().clearError();
if (key!=null) {
throw new RuntimeException("Not yet implemented");
}
CErrorImpl.getInstance().clearError();
String s = string.toString();
position =
((s.charAt(0)&0xff)<<24)+
((s.charAt(1)&0xff)<<16)+
((s.charAt(2)&0xff)<<8)+
((s.charAt(3)&0xff))-1;
get(position);
}
private void get(int position)
{
try {
preserveRead();
stream.reset();
file.seek(position);
while ( true ) {
int c = file.read();
if (c==-1) break;
if (appendToStream( (char) c )) break;
}
} catch (IOException e) {
CErrorImpl.getInstance().setError(35,e.getMessage());
}
copyStreamToRecord();
}
@Override
public void remove() {
close();
String fname=getProperty(Prop.NAME).toString().trim();
CErrorImpl.getInstance().clearError();
ClarionFileFactory.getInstance().delete(fname);
}
@Override
public void reset(ClarionKey key,ClarionString string)
{
if (key!=null) {
throw new RuntimeException("Not supported");
}
String s = string.toString();
set(
((s.charAt(0)&0xff)<<24)+
((s.charAt(1)&0xff)<<16)+
((s.charAt(2)&0xff)<<8)+
((s.charAt(3)&0xff)));
}
@Override
public void set(int pos)
{
CErrorImpl.getInstance().clearError();
readPosition=pos-1;
}
@Override
public void restoreState(int state)
{
throw new RuntimeException("Not supported");
}
private Pattern sendPattern;
@Override
public void send(String operator) {
operator=operator.toLowerCase();
if (sendPattern==null) sendPattern=Pattern.compile("^\\s*/?\\s*(clip|tab|ctrlziseof|endofrecord|quickscan)\\s*=\\s*(.*?)\\s*$");
Matcher m = sendPattern.matcher(operator);
if (!m.matches()) throw new RuntimeException("Send command unknown:"+operator);
String key = m.group(1);
String value = m.group(2);
if (key.equals("clip")) {
clip=value.equals("on");
}
if (key.equals("tab")) {
tab=Integer.parseInt(value);
}
}
@Override
public void set(ClarionKey key)
{
if (key!=null) {
throw new RuntimeException("Not yet implemented");
}
readPosition=0;
}
@Override
public void setNulls(ClarionString nulls)
{
throw new RuntimeException("Not supported");
}
@Override
public void stream()
{
}
@Override
public void unlock()
{
}
@Override
public void watch()
{
throw new RuntimeException("Not supported");
}
@Override
protected String getDriver() {
return "ASCII";
}
private int readLookahead=-1;
private int readPosition=-1;
private int preLookaheadPosition=0;
private void preserveRead() throws IOException
{
readLookahead=-1;
if (readPosition==-1) {
readPosition=readPosition();
}
}
private int readPosition() throws IOException
{
if (readPosition>=0) return readPosition;
if (readLookahead==-1) {
return (int)file.position();
} else {
return preLookaheadPosition;
}
}
private int lookahead(boolean rememberPosition) throws IOException
{
if (readLookahead==-1) {
if (readPosition>=0) {
file.seek(readPosition);
readPosition=-1;
}
if (rememberPosition) {
preLookaheadPosition=(int)file.position();
}
readLookahead=file.read();
}
return readLookahead;
}
private int read() throws IOException
{
int result = lookahead(false);
readLookahead=-1;
return result;
}
@Override
public void copyTo(String target) {
CFile.copyFile(getName().toString(),target);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy