Hihi, Kienan, I finally find a workaround. I could success with the following code: file_name = "bt_plugin_latency_filter.py" current_directory=os.getcwd() file_path = os.path.join(current_directory, file_name) pset=bt2.find_plugins_in_path(file_path) forplugininpset: if plugin.name=="latency_filter"and hasattr(plugin,"filter_component_classes"): latency_filter_comp_cls=plugin.filter_component_classes['LatencyFilter'] But loading the whole directory, it just doesnt work from command line. Amanda ________________________________ From: Kienan Stewart Sent: Thursday, April 25, 2024 11:43:05 PM To: Wu, Yannan; lttng-dev@lists.lttng.org Subject: RE: [EXTERNAL] [lttng-dev] [babeltrace2]about python self-defined plugin loading CAUTION: This email originated from outside of the organization. Do not click links or open attachments unless you can confirm the sender and know the content is safe. My apologies, there is a typo in my previous e-mail, the library directory should be: `/babeltrace2/plugin-providers/' thanks, kienan On 4/25/24 11:41 AM, Kienan Stewart via lttng-dev wrote: > Hi Amanda, > > could you double-check to ensure that babeltrace2 was built with > `--enable-python-plugins`, and that `import bt2` works? > > There should be a babeltrace2-python-plugin-provider.so in > `/babeltrace2/plugin-provides` > > thanks, > kienan > > > On 4/24/24 11:28 PM, Wu, Yannan via lttng-dev wrote: >> Hi, There, >> >> I am trying to construct a customized filter and sink based on >> babeltrace2 python binding. However, nether mine plugin nor the >> plugins sample I could find on the internet all dont work. >> >> For example, >> https://github.com/simark/babeltrace-fun-plugins/tree/master/my-first-components >> >> I just downloaded the py file and run the exact command, it failed. >> The log is as following: >> >> >> babeltrace2 --plugin-path . -c source.demo.MyFirstSource -c >> sink.demo.MyFirstSink >> 04-24 16:52:04.349 919805 919805 E CLI >> add_descriptor_to_component_descriptor_set@babeltrace2.c:1720 Cannot >> find component class: plugin-name="demo", >> comp-cls-name="MyFirstSource", comp-cls-type=1 >> 04-24 16:52:04.349 919805 919805 E CLI >> cmd_run_ctx_init@babeltrace2.c:1882 Cannot find an operative message >> interchange protocol version to use to create the `run` command's >> graph: status=ERROR >> 04-24 16:52:04.349 919805 919805 E CLI cmd_run@babeltrace2.c:2465 >> Cannot initialize the command's context. >> >> ERROR: [Babeltrace CLI] (babeltrace2.c:2465) >> Cannot initialize the command's context. >> CAUSED BY [Babeltrace CLI] (babeltrace2.c:1882) >> Cannot find an operative message interchange protocol version to >> use to create the `run` command's graph: status=ERROR >> CAUSED BY [Babeltrace CLI] (babeltrace2.c:1720) >> Cannot find component class: plugin-name="demo", >> comp-cls-name="MyFirstSource", comp-cls-type=1 >> >> babeltrace2 --version >> Babeltrace 2.0.7 "Amqui" [v2.0.6-1-g825a0ed6d] >> >> Amqui (/ɒmkwiː/) is a town in eastern Québec, Canada, at the base of >> the Gaspé peninsula in Bas-Saint-Laurent. Located at the >> confluence of the Humqui and Matapédia Rivers, its proximity to >> woodlands makes it a great destination for outdoor activities such as >> camping, hiking, and mountain biking. >> yannanwu@ue91e96f2951b5c:~/trees/lttng_test_run$ >> >> Is the cli changed or something? How can I make it right? >> >> Besides, is it possible we create a pipeline in python and make use >> the the python drafted plugin? Can you advise me how? >> >> Amanda >> >> >> >> _______________________________________________ >> lttng-dev mailing list >> lttng-dev@lists.lttng.org >> https://lists.lttng.org/cgi-bin/mailman/listinfo/lttng-dev > _______________________________________________ > lttng-dev mailing list > lttng-dev@lists.lttng.org > https://lists.lttng.org/cgi-bin/mailman/listinfo/lttng-dev