2 * Copyright (c) 2014 Samsung Electronics Co., Ltd.
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
8 * http://www.apache.org/licenses/LICENSE-2.0
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.
19 #include "trigger-event.h"
22 #include <sys/eventfd.h>
25 #include <dali/integration-api/debug.h>
29 #include <file-descriptor-monitor.h>
40 TriggerEvent::TriggerEvent( CallbackBase* callback, TriggerEventInterface::Options options )
41 : mFileDescriptorMonitor( NULL ),
42 mCallback( callback ),
43 mFileDescriptor( -1 ),
46 // Create accompanying file descriptor.
47 mFileDescriptor = eventfd(0, EFD_NONBLOCK);
48 if (mFileDescriptor >= 0)
50 // Now Monitor the created event file descriptor
51 mFileDescriptorMonitor = new FileDescriptorMonitor( mFileDescriptor, MakeCallback( this, &TriggerEvent::Triggered ), FileDescriptorMonitor::FD_READABLE );
55 DALI_LOG_ERROR("Unable to create TriggerEvent File descriptor\n");
59 TriggerEvent::~TriggerEvent()
61 delete mFileDescriptorMonitor;
64 if (mFileDescriptor >= 0)
66 close(mFileDescriptor);
71 void TriggerEvent::Trigger()
73 if (mFileDescriptor >= 0)
75 // Increment event counter by 1.
76 // Writing to the file descriptor triggers the Dispatch() method in the other thread
77 // (if in multi-threaded environment).
80 int size = write(mFileDescriptor, &data, sizeof(uint64_t));
82 if (size != sizeof(uint64_t))
84 DALI_LOG_ERROR("Unable to write to UpdateEvent File descriptor\n");
89 DALI_LOG_WARNING("Attempting to write to an invalid file descriptor\n");
93 void TriggerEvent::Triggered( FileDescriptorMonitor::EventType eventBitMask )
95 if( !( eventBitMask & FileDescriptorMonitor::FD_READABLE ) )
97 DALI_ASSERT_ALWAYS( 0 && "Trigger event file descriptor error");
101 // Reading from the file descriptor resets the event counter, we can ignore the count.
102 uint64_t receivedData;
104 size = read(mFileDescriptor, &receivedData, sizeof(uint64_t));
105 if (size != sizeof(uint64_t))
107 DALI_LOG_WARNING("Unable to read to UpdateEvent File descriptor\n");
110 // Call the connected callback
111 CallbackBase::Execute( *mCallback );
113 //check if we should delete ourselves after the trigger
114 if( mOptions == TriggerEventInterface::DELETE_AFTER_TRIGGER )
120 } // namespace Adaptor
122 } // namespace Internal