mirror of
https://github.com/tearshark/librf.git
synced 2024-10-04 08:50:31 +08:00
41 lines
964 B
C++
41 lines
964 B
C++
|
|
#include <chrono>
|
|
#include <iostream>
|
|
#include <string>
|
|
#include <thread>
|
|
|
|
#include "librf.h"
|
|
|
|
using namespace resumef;
|
|
|
|
future_t<> test_routine_use_timer()
|
|
{
|
|
using namespace std::chrono;
|
|
|
|
for (size_t i = 0; i < 3; ++i)
|
|
{
|
|
co_await resumef::sleep_for(100ms);
|
|
std::cout << "timer after 100ms" << std::endl;
|
|
std::cout << "1:frame=" << __builtin_coro_frame() << std::endl;
|
|
}
|
|
}
|
|
|
|
future_t<> test_routine_use_timer_2()
|
|
{
|
|
std::cout << "test_routine_use_timer_2" << std::endl;
|
|
|
|
co_await test_routine_use_timer();
|
|
std::cout << "2:frame=" << __builtin_coro_frame() << std::endl;
|
|
co_await test_routine_use_timer();
|
|
std::cout << "2:frame=" << __builtin_coro_frame() << std::endl;
|
|
co_await test_routine_use_timer();
|
|
std::cout << "2:frame=" << __builtin_coro_frame() << std::endl;
|
|
}
|
|
|
|
void resumable_main_routine()
|
|
{
|
|
//go test_routine_use_timer_2();
|
|
go test_routine_use_timer();
|
|
this_scheduler()->run_until_notask();
|
|
}
|