KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > db4o > test > acid > LoggingIoAdapter


1 /* Copyright (C) 2004 - 2006 db4objects Inc. http://www.db4o.com
2
3 This file is part of the db4o open source object database.
4
5 db4o is free software; you can redistribute it and/or modify it under
6 the terms of version 2 of the GNU General Public License as published
7 by the Free Software Foundation and as clarified by db4objects' GPL
8 interpretation policy, available at
9 http://www.db4o.com/about/company/legalpolicies/gplinterpretation/
10 Alternatively you can write to db4objects, Inc., 1900 S Norfolk Street,
11 Suite 350, San Mateo, CA 94403, USA.
12
13 db4o is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 for more details.
17
18 You should have received a copy of the GNU General Public License along
19 with this program; if not, write to the Free Software Foundation, Inc.,
20 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */

21 package com.db4o.test.acid;
22
23 import java.io.*;
24
25 import com.db4o.io.*;
26
27 public class LoggingIoAdapter extends VanillaIoAdapter {
28     private final static int READ=1;
29     private final static int WRITE=2;
30     private final static int SYNC=4;
31     
32     private PrintStream _out;
33     private int _config;
34     private long _curpos;
35     
36     public LoggingIoAdapter(IoAdapter delegateAdapter,PrintStream out) {
37         this(delegateAdapter,out,WRITE);
38     }
39
40     public LoggingIoAdapter(IoAdapter delegateAdapter,PrintStream out,int config) {
41         super(delegateAdapter);
42         _out=out;
43         _config=config;
44     }
45
46     private LoggingIoAdapter(IoAdapter delegateAdapter, String JavaDoc path, boolean lockFile, long initialLength, PrintStream out,int config) throws IOException {
47         super(delegateAdapter.open(path, lockFile, initialLength));
48         _out=out;
49         _config=config;
50         _curpos=0;
51     }
52
53     public IoAdapter open(String JavaDoc path, boolean lockFile, long initialLength) throws IOException {
54         return new LoggingIoAdapter(_delegate,path,lockFile,initialLength,_out,_config);
55     }
56
57     public int read(byte[] bytes, int length) throws IOException {
58         if(config(READ)) {
59             _out.println("READ "+_curpos+","+length);
60         }
61         return _delegate.read(bytes, length);
62     }
63
64     public void seek(long pos) throws IOException {
65         _curpos=pos;
66         _delegate.seek(pos);
67     }
68
69     public void sync() throws IOException {
70         if(config(SYNC)) {
71             _out.println("SYNC");
72         }
73         _delegate.sync();
74     }
75
76     public void write(byte[] buffer, int length) throws IOException {
77         if(config(WRITE)) {
78             _out.println("WRITE "+_curpos+","+length);
79         }
80         _delegate.write(buffer, length);
81     }
82
83     private boolean config(int mask) {
84         return (_config&mask)!=0;
85     }
86 }
87
Popular Tags