diff options
-rw-r--r-- | RTJava/ChangeLog | 14 | ||||
-rw-r--r-- | RTJava/README | 5 | ||||
-rw-r--r-- | RTJava/docs/CodingStyle.txt | 8 | ||||
-rw-r--r-- | RTJava/examples/tank/Refiller.java | 26 | ||||
-rw-r--r-- | RTJava/examples/tank/Tank.java | 72 |
5 files changed, 125 insertions, 0 deletions
diff --git a/RTJava/ChangeLog b/RTJava/ChangeLog index b3139252db0..8fd28d94be1 100644 --- a/RTJava/ChangeLog +++ b/RTJava/ChangeLog @@ -1,3 +1,17 @@ +Fri Feb 02 19:49:28 2001 Angelo Corsaro <corsaro@cs.wustl.edu> + + * README: + Added some more notes... But not completed yet. + + * docs/CodingStyle.txt: + Added file cotaining the coding style that should be used. + + * examples/tank/Refiller.java: + * examples/tank/Bucket.java: + Created new example that will show how to use perioric + task as well as Asynchronous event handlers and other + RT Java features. + Fri Feb 02 00:59:59 2001 Angelo Corsaro <corsaro@cs.wustl.edu> * benchmarks/RawSpeed: diff --git a/RTJava/README b/RTJava/README index a6f91b22b09..4b32c22c60d 100644 --- a/RTJava/README +++ b/RTJava/README @@ -1,3 +1,8 @@ This directory contains a series of benchmarks for evaluating the RealTime JVM performance, and a series of example that are intented to show how certain feature of the RT Java should be used. + +Make sure you read the file docs/CodingStyle.txt before you start +adding code to the repository, so that all our code can look uniform +and it will be easier for all of us to understand and read each +other code.
\ No newline at end of file diff --git a/RTJava/docs/CodingStyle.txt b/RTJava/docs/CodingStyle.txt new file mode 100644 index 00000000000..e0e70b73e78 --- /dev/null +++ b/RTJava/docs/CodingStyle.txt @@ -0,0 +1,8 @@ +The coding guideline to be used are those specified by the +document "Java[tm] Coding Style Guide" that can be found at: + + http://www.sun.com/forte/whitepapers/ + + + + diff --git a/RTJava/examples/tank/Refiller.java b/RTJava/examples/tank/Refiller.java new file mode 100644 index 00000000000..1ceea495854 --- /dev/null +++ b/RTJava/examples/tank/Refiller.java @@ -0,0 +1,26 @@ +package tank; + +/** + * This class represent an activity that refills periodically + * the bucket. In this application it is assumed that this activity + * should be carried periodically. + */ +public class Refiller implements java.lang.Runnable { + + /** + * Constructs a refiller that refills the tank every + * given amount of time. + * + * @param period The period of time at which the refill should + * occur. + */ + public Refiller(int period) { + this.period = period; + } + + public Refiller(int period) { + this.period = period; + } + + protected long period; +} diff --git a/RTJava/examples/tank/Tank.java b/RTJava/examples/tank/Tank.java new file mode 100644 index 00000000000..41483d8f266 --- /dev/null +++ b/RTJava/examples/tank/Tank.java @@ -0,0 +1,72 @@ +package tank; + +/** + * This class represent a bucket from which some kind of + * liquid ca be refilled or spilled. + */ +public class Tank { + + /** + * Creates a bucket that can contains at most a given + * amount of liquid and that has initially available a + * given quantity. + * + * @param capacity The capacity of the Tank in liters. + * @param available The quantity of liquid initially available in + * the bucket. + */ + public Tank(long capacity, long available) { + this.capacity = capacity; + this.available = abailable; + } + + /** + * Refills the bucket with a given amount of liquid. + * + * @param amount The amount of liquid added to the bucket. + */ + public void refill(long amount) { + this.available = java.lang.Math.min(this.capacity, amount+this.available); + + // Here we should check for an overflow. + if (this.available > capacity) + this.overflowEvent.fire(); + } + + /** + * Spills from the bucket a given amount of liquid. + * + * @param amount The amount of liquid added to the bucket. + */ + public void spill(long amount) { + this.available = java.lang.Math.max(0, this.available-amount); + if (this.available < amount) + this.underflowEven.fire(); + } + + /** + * Adds an AsyncEventHandler that will be called by the scheduler + * each time an overflow occurs. + * + * @param handler Ther overflow handler. + */ + public void addOverflowHandler(AsyncEventHandler handler) { + this.overflowEvent.addHandler(handler); + } + + /** + * Adds an AsyncEventHandler that will be called by the scheduler + * each time an underflow occurs. + * + * @param handler Ther underflow handler. + */ + public void addUnderflowHandler(AsyncEventHandler handler) { + this.underflowEvent.addHandler(handler); + } + + protected long capacity; + protected long available; + + protected AsynchEvent overflowEvent; + protected AsynchEven underflowEvent; +} |