/*
* Tencent is pleased to support the open source community by making
* Tencent GT (Version 2.4 and subsequent versions) available.
*
* Notwithstanding anything to the contrary herein, any previous version
* of Tencent GT shall not be subject to the license hereunder.
* All right, title, and interest, including all intellectual property rights,
* in and to the previous version of Tencent GT (including any and all copies thereof)
* shall be owned and retained by Tencent and subject to the license under the
* Tencent GT End User License Agreement (http://gt.qq.com/wp-content/EULA_EN.html).
*
* Copyright (C) 2015 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the MIT License (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of the License at
*
* http://opensource.org/licenses/MIT
*
* Unless required by applicable law or agreed to in writing, software distributed
* under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the
* specific language governing permissions and limitations under the License.
*/
package com.tencent.wstt.gt.data;
import com.tencent.wstt.gt.AidlTask;
import com.tencent.wstt.gt.Functions;
import com.tencent.wstt.gt.PerfDigitalEntry;
import com.tencent.wstt.gt.data.local.LocalEndTimePerfEntry;
import com.tencent.wstt.gt.data.local.LocalNumberDataPerfEntry;
import com.tencent.wstt.gt.data.local.LocalStartTimePerfEntry;
/**
* 本地耗时统计数据的缓存
*/
public class LocalTimePerfCache extends PerfDataCache {
@Override
public AidlTask profiler(LocalNumberDataPerfEntry... endDataEntry) {
if (null == endDataEntry || endDataEntry.length == 0) {
return null;
}
LocalNumberDataPerfEntry end = endDataEntry[0];
if (!(end instanceof LocalEndTimePerfEntry))
{
return null;
}
LocalNumberDataPerfEntry start = get(end.getQueryEntry());
if (!(start instanceof LocalStartTimePerfEntry))
{
return null;
}
PerfDigitalEntry result = new PerfDigitalEntry();
result.setFunctionId(Functions.PERF_REDUCE_TIME);
result.setQueryEntry(end.getQueryEntry());
result.setLogTime(end.getLogTime());
result.setData(end.getData() - start.getData());
return result;
}
}