WebCFace 2.5.2
Web-based Communication Framework & Dashboard-like UI
Loading...
Searching...
No Matches
Func Class Reference

関数1つを表すクラス More...

#include <webcface/func.h>

Inheritance diagram for Func:
[legend]
Collaboration diagram for Func:
[legend]

Public Types

using FuncType = void(CallHandle)
 

Public Member Functions

 Func ()=default
 
 Func (const Field &base)
 
 Func (const Field &base, const SharedString &field)
 
Func child (std::string_view field) const
 「(thisの名前).(追加の名前)」を新しい名前とするField
 
Func child (std::wstring_view field) const
 「(thisの名前).(追加の名前)」を新しい名前とするField (wstring)
 
Func child (int index) const
 
Func operator[] (std::string_view field) const
 
Func operator[] (std::wstring_view field) const
 
Func operator[] (const char *field) const
 
Func operator[] (const wchar_t *field) const
 
Func operator[] (int index) const
 
Func parent () const
 nameの最後のピリオドの前までを新しい名前とするField
 
template<typename T , typename traits::FuncObjTrait< T >::ReturnTypeTrait::ReturnTypeSupportedByWebCFaceFunc = traits::TraitOk, typename traits::FuncObjTrait< T >::ArgTypesTrait::ArgTypesSupportedByWebCFaceFunc = traits::TraitOk>
const Funcset (T func) const
 関数をセットする
 
template<typename T , typename traits::FuncObjTrait< T >::ReturnTypeTrait::ReturnTypeSupportedByWebCFaceFunc = traits::TraitOk, typename traits::FuncObjTrait< T >::ArgTypesTrait::ArgTypesSupportedByWebCFaceFunc = traits::TraitOk>
const FuncsetAsync (T func) const
 非同期に実行される関数をセットする
 
template<typename T >
const Funcoperator= (T func) const
 関数をセットする
 
template<typename T , typename std::enable_if_t< std::is_same_v< std::invoke_result_t< T, CallHandle >, void >, std::nullptr_t > = nullptr>
const Funcset (std::vector< Arg > args, ValType return_type, T callback) const
 引数にCallHandleを取る関数を登録する
 
template<typename T , typename std::enable_if_t< std::is_same_v< std::invoke_result_t< T, CallHandle >, void >, std::nullptr_t > = nullptr>
const FuncsetAsync (std::vector< Arg > args, ValType return_type, T callback) const
 引数にFuncCallHandleを取り非同期に実行される関数を登録する
 
template<typename T , typename std::enable_if_t< std::is_same_v< std::invoke_result_t< T, CallHandle >, void >, std::nullptr_t > = nullptr>
const Funcset (T callback) const
 引数にCallHandleを取る関数を登録する
 
template<typename T , typename std::enable_if_t< std::is_same_v< std::invoke_result_t< T, CallHandle >, void >, std::nullptr_t > = nullptr>
const FuncsetAsync (T callback) const
 引数にFuncCallHandleを取り非同期に実行される関数を登録する
 
const Funchidden (bool) const
 関数を関数リストで非表示にする (他clientのentryに表示されなくする)
 
const Funcfree () const
 関数の設定を削除
 
template<typename... Args>
ValAdaptor run (Args... args) const
 関数を実行する (同期)
 
ValAdaptor run (std::vector< ValAdaptor > &&args_vec) const
 
template<typename... Args>
ValAdaptor operator() (Args... args) const
 run()と同じ
 
template<typename... Args>
Promise runAsync (Args... args) const
 関数を実行する (非同期)
 
Promise runAsync (std::vector< ValAdaptor > args_vec) const
 
bool exists () const
 関数の情報が存在すればtrue
 
ValType returnType () const
 戻り値の型を返す
 
std::vector< Argargs () const
 引数の情報を返す
 
const Arg args (std::size_t i) const
 
const FuncsetArgs (const std::vector< Arg > &args) const
 引数の情報を更新する
 
const FuncsetReturnType (ValType return_type) const
 戻り値の型の情報を更新する
 
template<typename T , typename std::enable_if_t< std::is_same_v< T, Func >, std::nullptr_t > = nullptr>
bool operator== (const T &other) const
 Funcの参照先を比較
 
template<typename T , typename std::enable_if_t< std::is_same_v< T, Func >, std::nullptr_t > = nullptr>
bool operator!= (const T &other) const
 
std::string lastName () const
 nameのうちピリオドで区切られた最後の部分を取り出す
 
Member member () const
 Memberを返す
 
const std::string & name () const
 field名を返す
 
const std::wstring & nameW () const
 field名を返す (wstring)
 

Protected Member Functions

const FuncsetImpl (ValType return_type, std::vector< Arg > &&args, std::function< FuncType > &&func_impl) const
 
const FuncsetImpl (ValType return_type, std::nullopt_t, std::function< FuncType > &&func_impl) const
 
const FuncsetImpl (const std::shared_ptr< internal::FuncInfo > &func_info) const
 
std::shared_ptr< internal::ClientDatadataLock () const
 data_wをlockし、失敗したらruntime_errorを投げる
 
std::shared_ptr< internal::ClientDatasetCheck () const
 data_wをlockし、memberがselfではなければinvalid_argumentを投げる
 
bool expired () const
 
SharedString lastName8 () const
 
Field child (const SharedString &field) const
 
std::wstring lastNameW () const
 nameのうちピリオドで区切られた最後の部分を取り出す (wstring)
 
Value value (std::string_view field="") const
 
Value value (std::wstring_view field) const
 
Text text (std::string_view field="") const
 
Text text (std::wstring_view field) const
 
RobotModel robotModel (std::string_view field="") const
 
RobotModel robotModel (std::wstring_view field) const
 
Image image (std::string_view field="") const
 
Image image (std::wstring_view field) const
 
Func func (std::string_view field="") const
 
Func func (std::wstring_view field) const
 
FuncListener funcListener (std::string_view field) const
 
FuncListener funcListener (std::wstring_view field) const
 
View view (std::string_view field="") const
 
View view (std::wstring_view field) const
 
Canvas3D canvas3D (std::string_view field="") const
 
Canvas3D canvas3D (std::wstring_view field) const
 
Canvas2D canvas2D (std::string_view field="") const
 
Canvas2D canvas2D (std::wstring_view field) const
 
Log log (std::string_view field="") const
 
Log log (std::wstring_view field) const
 
std::vector< ValuevalueEntries () const
 
std::vector< TexttextEntries () const
 
std::vector< RobotModelrobotModelEntries () const
 
std::vector< FuncfuncEntries () const
 
std::vector< ViewviewEntries () const
 
std::vector< Canvas3Dcanvas3DEntries () const
 
std::vector< Canvas2Dcanvas2DEntries () const
 
std::vector< ImageimageEntries () const
 
std::vector< LoglogEntries () const
 
bool isSelf () const
 memberがselfならtrue
 
bool operator== (const Field &other) const
 
bool operator== (const FieldBase &rhs) const
 
bool operator!= (const Field &other) const
 
bool operator!= (const FieldBase &rhs) const
 

Static Protected Member Functions

template<typename F1 >
static void catchAll (F1 &&f_run, const CallHandle &handle)
 
template<typename F1 >
static void tryRun (F1 &&f_run, const CallHandle &handle)
 

Protected Attributes

std::weak_ptr< internal::ClientDatadata_w
 ClientDataの参照
 
SharedString member_
 メンバー名
 
SharedString field_
 フィールド名
 

Friends

class TemporalViewComponent
 
class TemporalCanvas2DComponent
 

Detailed Description

関数1つを表すクラス

Member Typedef Documentation

◆ FuncType

using FuncType = void (CallHandle)

Constructor & Destructor Documentation

◆ Func() [1/3]

Func ( )
default

◆ Func() [2/3]

Func ( const Field base)

◆ Func() [3/3]

Func ( const Field base,
const SharedString field 
)
inline

Member Function Documentation

◆ args() [1/2]

std::vector< Arg > args ( ) const

引数の情報を返す

変更するにはsetArgsを使う(このvectorの中身を書き換えても反映されない)

◆ args() [2/2]

const Arg args ( std::size_t  i) const
inline

◆ canvas2D() [1/2]

Canvas2D canvas2D ( std::string_view  field = "") const
inherited

◆ canvas2D() [2/2]

Canvas2D canvas2D ( std::wstring_view  field) const
inherited

◆ canvas2DEntries()

std::vector< Canvas2D > canvas2DEntries ( ) const
inherited

◆ canvas3D() [1/2]

Canvas3D canvas3D ( std::string_view  field = "") const
inherited

◆ canvas3D() [2/2]

Canvas3D canvas3D ( std::wstring_view  field) const
inherited

◆ canvas3DEntries()

std::vector< Canvas3D > canvas3DEntries ( ) const
inherited

◆ catchAll()

template<typename F1 >
static void catchAll ( F1 &&  f_run,
const CallHandle handle 
)
inlinestaticprotected

f_run()を実行し例外を投げた場合はrejectする

◆ child() [1/4]

Field child ( const SharedString field) const
inherited

◆ child() [2/4]

Func child ( int  index) const
inline
Since
ver1.11

◆ child() [3/4]

Func child ( std::string_view  field) const
inline

「(thisの名前).(追加の名前)」を新しい名前とするField

◆ child() [4/4]

Func child ( std::wstring_view  field) const
inline

「(thisの名前).(追加の名前)」を新しい名前とするField (wstring)

Since
ver2.0

◆ dataLock()

std::shared_ptr< internal::ClientData > dataLock ( ) const
inherited

data_wをlockし、失敗したらruntime_errorを投げる

◆ exists()

bool exists ( ) const

関数の情報が存在すればtrue

Since
ver2.1

◆ expired()

bool expired ( ) const
inherited

◆ free()

const Func & free ( ) const

関数の設定を削除

◆ func() [1/2]

Func func ( std::string_view  field = "") const
inherited

◆ func() [2/2]

Func func ( std::wstring_view  field) const
inherited

◆ funcEntries()

std::vector< Func > funcEntries ( ) const
inherited

◆ funcListener() [1/2]

FuncListener funcListener ( std::string_view  field) const
inherited

◆ funcListener() [2/2]

FuncListener funcListener ( std::wstring_view  field) const
inherited

◆ hidden()

const Func & hidden ( bool  ) const
inline

関数を関数リストで非表示にする (他clientのentryに表示されなくする)

Deprecated:
ver1.10から、名前が半角ピリオドで始まるかどうかで判断されるように仕様変更したため、 hiddenの指定は無効 (この関数は効果がない)

◆ image() [1/2]

Image image ( std::string_view  field = "") const
inherited

◆ image() [2/2]

Image image ( std::wstring_view  field) const
inherited

◆ imageEntries()

std::vector< Image > imageEntries ( ) const
inherited

◆ isSelf()

bool isSelf ( ) const
inherited

memberがselfならtrue

data_wがlockできなければruntime_errorを投げる

◆ lastName()

std::string lastName ( ) const
inline

nameのうちピリオドで区切られた最後の部分を取り出す

Since
ver1.11

◆ lastName8()

SharedString lastName8 ( ) const
protectedinherited

◆ lastNameW()

std::wstring lastNameW ( ) const
inlineinherited

nameのうちピリオドで区切られた最後の部分を取り出す (wstring)

Since
ver2.0

◆ log() [1/2]

Log log ( std::string_view  field = "") const
inherited
Since
ver2.4

◆ log() [2/2]

Log log ( std::wstring_view  field) const
inherited
Since
ver2.4

◆ logEntries()

std::vector< Log > logEntries ( ) const
inherited
Since
ver2.4

◆ member()

Member member ( ) const

Memberを返す

◆ name()

const std::string & name ( ) const
inline

field名を返す

◆ nameW()

const std::wstring & nameW ( ) const
inline

field名を返す (wstring)

Since
ver2.0

◆ operator!=() [1/3]

bool operator!= ( const Field other) const
inlineinherited

◆ operator!=() [2/3]

bool operator!= ( const FieldBase rhs) const
inlineinherited

◆ operator!=() [3/3]

template<typename T , typename std::enable_if_t< std::is_same_v< T, Func >, std::nullptr_t > = nullptr>
bool operator!= ( const T &  other) const
inline

◆ operator()()

template<typename... Args>
ValAdaptor operator() ( Args...  args) const
inline

run()と同じ

Deprecated:
ver2.0〜

◆ operator=()

template<typename T >
const Func & operator= ( func) const
inline

関数をセットする

set() と同じ。

Deprecated:
ver2.0〜 set()とsetAsync()に分かれたので、代入演算子だとわかりづらい また、 operator=(const Func &) との区別もつきづらい

◆ operator==() [1/3]

bool operator== ( const Field other) const
inherited

◆ operator==() [2/3]

bool operator== ( const FieldBase rhs) const
inlineinherited

◆ operator==() [3/3]

template<typename T , typename std::enable_if_t< std::is_same_v< T, Func >, std::nullptr_t > = nullptr>
bool operator== ( const T &  other) const
inline

Funcの参照先を比較

Since
ver1.11

◆ operator[]() [1/5]

Func operator[] ( const char *  field) const
inline

operator[](long, const char *)と解釈されるのを防ぐための定義

Since
ver1.11

◆ operator[]() [2/5]

Func operator[] ( const wchar_t *  field) const
inline
Since
ver2.0

◆ operator[]() [3/5]

Func operator[] ( int  index) const
inline

child()と同じ

Since
ver1.11

◆ operator[]() [4/5]

Func operator[] ( std::string_view  field) const
inline

child()と同じ

Since
ver1.11

◆ operator[]() [5/5]

Func operator[] ( std::wstring_view  field) const
inline

child()と同じ

Since
ver2.0

◆ parent()

Func parent ( ) const
inline

nameの最後のピリオドの前までを新しい名前とするField

Since
ver1.11

◆ returnType()

ValType returnType ( ) const

戻り値の型を返す

◆ robotModel() [1/2]

RobotModel robotModel ( std::string_view  field = "") const
inherited

◆ robotModel() [2/2]

RobotModel robotModel ( std::wstring_view  field) const
inherited

◆ robotModelEntries()

std::vector< RobotModel > robotModelEntries ( ) const
inherited

◆ run() [1/2]

template<typename... Args>
ValAdaptor run ( Args...  args) const
inline

関数を実行する (同期)

例外が発生した場合 runtime_error, 関数が存在しない場合 FuncNotFound をthrowする

Deprecated:
ver2.0〜 runAsync()を推奨。 Promise::waitFinish() と response(), rejection() で同等のことができるが、 使い方によってはデッドロックを起こす可能性がある。 詳細は waitFinish() のドキュメントを参照

◆ run() [2/2]

ValAdaptor run ( std::vector< ValAdaptor > &&  args_vec) const
inline

◆ runAsync() [1/2]

template<typename... Args>
Promise runAsync ( Args...  args) const
inline

関数を実行する (非同期)

  • 非同期で実行する。 戻り値やエラー、例外は Promise から取得する
  • 関数を実行したスレッドはdetachされるので、戻り値が不要な場合は Promise を破棄してもよい。 (std::async などとは異なる)
  • ver2.0~: runAsyncを呼んだ時点でclientがサーバーに接続していない場合、 関数呼び出しメッセージは送信されず呼び出しは失敗する (Promise::found() が false になる)

◆ runAsync() [2/2]

AsyncFuncResult runAsync ( std::vector< ValAdaptor args_vec) const

◆ set() [1/3]

template<typename T , typename std::enable_if_t< std::is_same_v< std::invoke_result_t< T, CallHandle >, void >, std::nullptr_t > = nullptr>
const Func & set ( std::vector< Arg args,
ValType  return_type,
callback 
) const
inline

引数にCallHandleを取る関数を登録する

Since
ver1.9
  • WebCFace内部でCのAPIからの呼び出しに使うためのもの
  • ver1.11まで: 関数がrespond()もreject()もせず終了した場合自動でrespondする。
  • ver2.0〜: 自動でrespondされることはないので、 関数が受け取ったhandleを別スレッドに渡すなどして、 ここでセットした関数の終了後にrespond()やreject()することも可能。
  • ver2.4〜: 例外をthrowした場合catchしてreject()する。
Parameters
args引数の型などの情報
return_type戻り値の型
funcセットする関数または関数オブジェクト。 引数としてCallHandleを1つ取り、戻り値はvoidで、 CallHandle::respond() や reject() を通して値を返す

◆ set() [2/3]

template<typename T , typename std::enable_if_t< std::is_same_v< std::invoke_result_t< T, CallHandle >, void >, std::nullptr_t > = nullptr>
const Func & set ( callback) const
inline

引数にCallHandleを取る関数を登録する

Since
ver2.4
  • 自動でrespondされることはないので、 関数が受け取ったhandleを別スレッドに渡すなどして、 ここでセットした関数の終了後にrespond()やreject()することも可能。
  • setArgs(), setReturnType() で引数の個数や型と戻り値の型を指定する。 指定しない場合、引数なし戻り値なしとみなされる。
  • 例外をthrowした場合catchしてreject()する。
Parameters
funcセットする関数または関数オブジェクト。 引数としてCallHandleを1つ取り、戻り値はvoidで、 CallHandle::respond() や reject() を通して値を返す

◆ set() [3/3]

template<typename T , typename traits::FuncObjTrait< T >::ReturnTypeTrait::ReturnTypeSupportedByWebCFaceFunc = traits::TraitOk, typename traits::FuncObjTrait< T >::ArgTypesTrait::ArgTypesSupportedByWebCFaceFunc = traits::TraitOk>
const Func & set ( func) const
inline

関数をセットする

  • ver2.0〜: set()でセットした場合、他クライアントから呼び出されたとき Client::recv() (または autoRecv) のスレッドでそのまま実行され、 この関数が完了するまで他のデータの受信はブロックされる。 また、 runAsync() で呼び出したとしても同じスレッドで同期実行される。
Parameters
funcセットする関数または関数オブジェクト。 引数はValAdaptorからキャスト可能な型ならいくつでも、 戻り値はvoidまたはValAdaptorにキャスト可能な型が使用可能
See also
setAsync()

◆ setArgs()

const Func & setArgs ( const std::vector< Arg > &  args) const

引数の情報を更新する

setArgsで渡された引数の情報(名前など)とFuncがすでに持っている引数の情報(型など)がマージされる

関数のセットの後に呼ばなければならない(セット前に呼ぶと std::invalid_argument) (例えば Func(...).set(...).setArgs({...}) ) また、関数をセットしたあと cli.sync() をする前に呼ばなければならない 実際にセットした関数の引数の数とargsの要素数は一致していなければならない (一致していない場合 std::invalid_argument )

◆ setAsync() [1/3]

template<typename T , typename std::enable_if_t< std::is_same_v< std::invoke_result_t< T, CallHandle >, void >, std::nullptr_t > = nullptr>
const Func & setAsync ( std::vector< Arg args,
ValType  return_type,
callback 
) const
inline

引数にFuncCallHandleを取り非同期に実行される関数を登録する

Since
ver2.0
  • WebCFace内部でCのAPIからの呼び出しに使うためのもの
  • 関数がrespond()もreject()もせず終了した場合自動でrespondされることはないので、 関数が受け取ったhandleを別スレッドに渡すなどして、 ここでセットした関数の終了後にrespond()やreject()することも可能。
  • ver2.4〜: 例外をthrowした場合catchしてreject()する。
Parameters
args引数の型などの情報
return_type戻り値の型
funcセットする関数または関数オブジェクト。 引数としてCallHandleを1つ取り、戻り値はvoidで、 CallHandle::respond() や reject() を通して値を返す

◆ setAsync() [2/3]

template<typename T , typename std::enable_if_t< std::is_same_v< std::invoke_result_t< T, CallHandle >, void >, std::nullptr_t > = nullptr>
const Func & setAsync ( callback) const
inline

引数にFuncCallHandleを取り非同期に実行される関数を登録する

Since
ver2.4
  • 自動でrespondされることはないので、 関数が受け取ったhandleを別スレッドに渡すなどして、 ここでセットした関数の終了後にrespond()やreject()することも可能。
  • setArgs(), setReturnType() で引数の個数や型と戻り値の型を指定する。 指定しない場合、引数なし戻り値なしとみなされる。
  • 例外をthrowした場合catchしてreject()する。
Parameters
funcセットする関数または関数オブジェクト。 引数としてCallHandleを1つ取り、戻り値はvoidで、 CallHandle::respond() や reject() を通して値を返す

◆ setAsync() [3/3]

template<typename T , typename traits::FuncObjTrait< T >::ReturnTypeTrait::ReturnTypeSupportedByWebCFaceFunc = traits::TraitOk, typename traits::FuncObjTrait< T >::ArgTypesTrait::ArgTypesSupportedByWebCFaceFunc = traits::TraitOk>
const Func & setAsync ( func) const
inline

非同期に実行される関数をセットする

Since
ver2.0
  • setAsync()でセットした場合、他クライアントから呼び出されたとき新しいスレッドを建てて実行される。 ver1.11以前のset()と同じ。
  • 排他制御などはセットする関数の側で用意してください。
Parameters
funcセットする関数または関数オブジェクト。 引数はValAdaptorからキャスト可能な型ならいくつでも、 戻り値はvoidまたはValAdaptorにキャスト可能な型が使用可能
See also
set()

◆ setCheck()

std::shared_ptr< internal::ClientData > setCheck ( ) const
inherited

data_wをlockし、memberがselfではなければinvalid_argumentを投げる

◆ setImpl() [1/3]

const Func & setImpl ( const std::shared_ptr< internal::FuncInfo > &  func_info) const
protected

◆ setImpl() [2/3]

const Func & setImpl ( ValType  return_type,
std::nullopt_t  ,
std::function< FuncType > &&  func_impl 
) const
protected

引数の個数不定バージョン

◆ setImpl() [3/3]

const Func & setImpl ( ValType  return_type,
std::vector< Arg > &&  args,
std::function< FuncType > &&  func_impl 
) const
protected

set2()で構築された関数の情報(FuncInfo)をclientにセット

◆ setReturnType()

const Func & setReturnType ( ValType  return_type) const

戻り値の型の情報を更新する

Since
ver2.4

set()やsetAsync()で通常の関数をセットした場合戻り値の型は自動的に取得されるので setReturnType() を呼ぶ必要はない。

◆ text() [1/2]

Text text ( std::string_view  field = "") const
inherited

◆ text() [2/2]

Text text ( std::wstring_view  field) const
inherited

◆ textEntries()

std::vector< Text > textEntries ( ) const
inherited

◆ tryRun()

template<typename F1 >
static void tryRun ( F1 &&  f_run,
const CallHandle handle 
)
inlinestaticprotected

f_run()を実行し結果をCallHandleに渡す

◆ value() [1/2]

Value value ( std::string_view  field = "") const
inherited

◆ value() [2/2]

Value value ( std::wstring_view  field) const
inherited

◆ valueEntries()

std::vector< Value > valueEntries ( ) const
inherited

◆ view() [1/2]

View view ( std::string_view  field = "") const
inherited

◆ view() [2/2]

View view ( std::wstring_view  field) const
inherited

◆ viewEntries()

std::vector< View > viewEntries ( ) const
inherited

Friends And Related Symbol Documentation

◆ TemporalCanvas2DComponent

friend class TemporalCanvas2DComponent
friend

◆ TemporalViewComponent

friend class TemporalViewComponent
friend

Member Data Documentation

◆ data_w

std::weak_ptr<internal::ClientData> data_w
inherited

ClientDataの参照

ClientData内に保持するクラスもあるので循環参照を避けるためweak_ptr

◆ field_

SharedString field_
inherited

フィールド名

Memberなどフィールド名が不要なクラスでは使用しない

◆ member_

SharedString member_
inherited

メンバー名


The documentation for this class was generated from the following files: