X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/24c420b78b1178fca4c2a8dbd331a10740f88728..7542865db86af7277605317aaa5c3b35a9dbba5a:/examples/java/async/waitAll/Receiver.java diff --git a/examples/java/async/waitAll/Receiver.java b/examples/java/async/waitAll/Receiver.java new file mode 100644 index 0000000000..84444fa89e --- /dev/null +++ b/examples/java/async/waitAll/Receiver.java @@ -0,0 +1,34 @@ +/* Copyright (c) 2006-2007, 2010, 2013-2014, 2016. The SimGrid Team. + * All rights reserved. */ + +/* This program is free software; you can redistribute it and/or modify it + * under the terms of the license (GNU LGPL) which comes with this package. */ + +package async.waitAll; +import org.simgrid.msg.Msg; +import org.simgrid.msg.Comm; +import org.simgrid.msg.Host; +import org.simgrid.msg.Task; +import org.simgrid.msg.Process; +import org.simgrid.msg.HostFailureException; +import org.simgrid.msg.TimeoutException; +import org.simgrid.msg.TransferFailureException; + +public class Receiver extends Process { + public Receiver (Host host, String name) { + super(host,name); + } + + public void main(String[] args) throws TransferFailureException, HostFailureException, TimeoutException { + Comm comm = Task.irecv(getHost().getName()); + Msg.info("I started receiving on '"+ getHost().getName() +". Wait 0.1 second, and block on the communication."); + waitFor(0.1); + try { + comm.waitCompletion(); + } catch (TimeoutException e) { + Msg.info("Timeout while waiting for my task"); + return; // Stop this process + } + Msg.info("I got my task, good bye."); + } +} \ No newline at end of file