1 /*
2 * This file is part of Waarp Project (named also Waarp or GG).
3 *
4 * Copyright (c) 2019, Waarp SAS, and individual contributors by the @author
5 * tags. See the COPYRIGHT.txt in the distribution for a full listing of
6 * individual contributors.
7 *
8 * All Waarp Project is free software: you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation, either version 3 of the License, or (at your
11 * option) any later version.
12 *
13 * Waarp is distributed in the hope that it will be useful, but WITHOUT ANY
14 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
15 * A PARTICULAR PURPOSE. See the GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License along with
18 * Waarp . If not, see <http://www.gnu.org/licenses/>.
19 */
20 package org.waarp.openr66.protocol.utils;
21
22 import org.waarp.common.future.WaarpFuture;
23 import org.waarp.openr66.context.R66Result;
24 import org.waarp.openr66.database.data.DbTaskRunner;
25
26 /**
27 * Future implementation
28 */
29 public class R66Future extends WaarpFuture {
30
31 private R66Result result;
32 /**
33 * Used in some specific occasion, such as client submission in API mode
34 */
35 private DbTaskRunner runner;
36 private long filesize;
37
38 /**
39 *
40 */
41 public R66Future() {
42 }
43
44 /**
45 * @param cancellable
46 */
47 public R66Future(final boolean cancellable) {
48 super(cancellable);
49 }
50
51 /**
52 * @return the result
53 */
54 public final R66Result getResult() {
55 return result;
56 }
57
58 /**
59 * @param result the result to set
60 */
61 public final void setResult(final R66Result result) {
62 this.result = result;
63 }
64
65 @Override
66 public final String toString() {
67 return "Future: " + isDone() + ' ' + isSuccess() + ' ' +
68 (getCause() != null? getCause().getMessage() : "no cause") + ' ' +
69 (result != null? result.toString() : "no result");
70 }
71
72 /**
73 * @return the runner
74 */
75 public final DbTaskRunner getRunner() {
76 return runner;
77 }
78
79 /**
80 * @param runner the runner to set
81 */
82 public final void setRunner(final DbTaskRunner runner) {
83 this.runner = runner;
84 }
85
86 /**
87 * @return the filesize
88 */
89 public final long getFilesize() {
90 return filesize;
91 }
92
93 /**
94 * @param filesize the filesize to set
95 */
96 public final void setFilesize(final long filesize) {
97 this.filesize = filesize;
98 }
99 }