blob: a0de0a93bc5ef8e55c5019d40bb1dc06071e0c0f [file] [log] [blame]
Jonathan Hartdb3af892015-01-26 13:19:07 -08001/*
2 * Copyright 2015 Open Networking Laboratory
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Jonathan Hart6ec029a2015-03-24 17:12:35 -070016package org.onosproject.store.service;
Jonathan Hartdb3af892015-01-26 13:19:07 -080017
18import org.onosproject.store.Timestamp;
19
20/**
Jonathan Hart5ec32ba2015-02-05 13:33:58 -080021 * Clock service that can generate timestamps based off of two input objects.
22 * Implementations are free to only take one or none of the objects into account
23 * when generating timestamps.
Jonathan Hartdb3af892015-01-26 13:19:07 -080024 */
Jonathan Hart5ec32ba2015-02-05 13:33:58 -080025public interface ClockService<T, U> {
Jonathan Hartdb3af892015-01-26 13:19:07 -080026
27 /**
Jonathan Hart5ec32ba2015-02-05 13:33:58 -080028 * Gets a new timestamp for the given objects.
Jonathan Hartdb3af892015-01-26 13:19:07 -080029 *
Jonathan Hart5ec32ba2015-02-05 13:33:58 -080030 * @param object1 First object to use when generating timestamps
31 * @param object2 Second object to use when generating timestamps
Jonathan Hartdb3af892015-01-26 13:19:07 -080032 * @return the new timestamp
33 */
Jonathan Hart5ec32ba2015-02-05 13:33:58 -080034 public Timestamp getTimestamp(T object1, U object2);
Jonathan Hartdb3af892015-01-26 13:19:07 -080035}