/*
* 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.log;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.LinkedBlockingQueue;
import com.tencent.wstt.gt.ui.model.LogEntry;
public class LogTaskConsumer {
private Thread thread;
private boolean flag;
protected boolean allowAdd2Visable = true;
private LinkedBlockingQueue<LogEntry> queue = new LinkedBlockingQueue<LogEntry>(1000);
LogTaskConsumer(final AbsLogController controller) {
controller.setLogTaskConsumer(this);
thread = new Thread(new Runnable() {
@Override
public void run() {
LogEntry temp = null;
try {
while (flag) {
Thread.sleep(500);
if (allowAdd2Visable) // 不允许加入可视图,就让queue爆吧
{
List<LogEntry> tempList = new ArrayList<LogEntry>();
if (null != temp)
{
tempList.add(temp);
}
queue.drainTo(tempList);
if (tempList.size() > 0)
{
controller.addEntrys(tempList);
}
temp = queue.take();
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}, LogTaskConsumer.this.getClass().getSimpleName());
}
public void start()
{
flag = true;
thread.setPriority(Thread.MIN_PRIORITY);
thread.start();
}
public void stop()
{
flag = false;
}
public void setAllowAdd2Visable(boolean allow)
{
this.allowAdd2Visable = allow;
}
public void putLog(LogEntry log) {
queue.offer(log);
}
}