Philippe Proulx [Wed, 8 Nov 2023 19:53:57 +0000 (14:53 -0500)]
cpp-common/bt2/borrowed-object.hpp: use BT_ASSERT_DBG()
bt2::BorrowedObject::BorrowedObject() obviously deserves a
BT_ASSERT_DBG() here because it's a common constructor for all wrapper
classes.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I05879bf2e6993fe836b57645e1451247008ac2ea
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11301
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Mon, 13 Nov 2023 20:32:19 +0000 (15:32 -0500)]
cpp-common/bt2/field.hpp: use raw value proxy for scalar classes
This patch makes field wrappers behave like value wrappers regarding
raw value access.
Now, the `*` operator of boolean, integer, floating point number, and
string fields return a raw value proxy to access the raw value:
void f(const bt2::UnsignedIntegerField val) {
*val = 23;
std::cout << *val << std::endl;
}
I didn't do it for `bt2::CommonBitArrayField` which is a scalar field,
but it's still an array, so it felt weird. Instead, use valueAsInteger()
or bitValue() depending on your use case.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I3bbcdc79a6dea781f720b7da8e18aea285d792b5
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11371
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Sat, 11 Nov 2023 16:46:36 +0000 (11:46 -0500)]
cpp-common/bt2: use raw value proxy for scalar value classes
This patch adds the `bt2::RawValueProxy` class of which an instance
contains a wrapper object `_mObj` and:
* Its `=` operator calls `_mObj.value()` to assign a value.
* Its raw value type operator returns what `_mObj.value()` returns.
Then, in scalar value wrapper classes of `value.hpp`:
* Remove the `=` operator which assigns a raw value.
* Add a value() method to assign a raw value.
* Add a `*` operator to return a raw value proxy containing this.
The goal of this patch is to avoid using the `=` operator on some value
object to both wrap another library object (pseudo copy assignment
operator) and assign a raw value. Now, to assign a raw value, you need
to "dereference" the wrapper object:
void f(const bt2::UnsignedIntegerValue val) {
*val = 23;
std::cout << *val << std::endl;
}
There's also `bt2::RawStringValueProxy` which adds the `=` operator to
`bt2::RawValueProxy` to assign a `const std::string&`.
`bt2::CommonStringValue` uses it.
Additionally, remove all the `=` operators to assign a raw value on
`bt2::CommonValue` and create a "master" raw value proxy class
(`CommonValueRawValueProxy`) to have all the `=` operators and raw value
type operators:
void f(const bt2::Value val) {
// We know it's a boolean value
*val = true;
}
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: Ia8559de36baba3021169b3d097ec83b914407f63
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11362
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Sat, 4 Nov 2023 20:43:11 +0000 (16:43 -0400)]
cpp-common/bt2/value.hpp: add proxy methods to `bt2::CommonValue`
Those new methods on `bt2::CommonValue` call the corresponding method
while "converting" the current object to another type for the user.
For example:
void f(const bt2::Value val)
{
// We know it's a string value
val = "mireille";
}
This is just sugar for common value operations to avoid the redundancy
of calling as*().
The as*() methods already have BT_ASSERT_DBG() lines to make sure that
the conversion is valid.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I475bda3754a984cbd2eca98f5caa14c765ece956
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11241
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Sat, 4 Nov 2023 20:04:46 +0000 (16:04 -0400)]
cpp-common/bt2: remove useless `_ThisXyz` type aliases
Name is injected so those private `_ThisXyz` type aliases are useless.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I4313729f63f4fe74622517d19dd986bd3393766b
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11239
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Sat, 4 Nov 2023 19:41:37 +0000 (15:41 -0400)]
cpp-common/bt2/value.hpp: move static assertion (wrong place)
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I3384fdcf4f570a2f15062bf64af3ac27d0caee72
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11238
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Simon Marchi [Mon, 11 Dec 2023 20:03:50 +0000 (15:03 -0500)]
cpp-common/bt2: rework `bt2::CommonIterator` (now `bt2::BorrowedObjectIterator`)
We don't need all the STL stuff (and constraints) currently, therefore
this iterator class may be simpler, making operator*() call
ContainerT::operator[]() directly instead of keeping a temporary wrapper
object and having a conditional for each iteration increment.
Making operator->() return a proxy because the iterator instance has no
persistent wrapper instance.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I1bdb254a37533b8524450b22aa7f25a4d8025c2c
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11236
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Tue, 5 Dec 2023 14:46:25 +0000 (09:46 -0500)]
cpp-common/bt2: add `bt2::BorrowedObjectProxy`
When bt2::Something::operator->() would need to return the address of
some `ObjT` instance, but none is available (because it only keeps the
libbabeltrace2 object pointer, not a built wrapper), then it can use
this new `bt2::BorrowedObjectProxy`.
This new class template accepts a library pointer at construction time,
constructs an internal `ObjT` instance, and its own operator->() method
returns the address of the latter.
Example:
class Something
{
// ...
public:
BorrowedObjectProxy<SomeObject> operator->() const noexcept
{
return BorrowedObjectProxy<SomeObject> {_mLibObjPtr};
}
private:
const bt_some_object *_mLibObjPtr;
};
Then, with a `Something` instance `something`:
something->methodOfSomeObject(...);
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I67d63591fb6593080a15e2ab6804a53bd2d2aba8
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11487
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Fri, 3 Nov 2023 18:48:52 +0000 (14:48 -0400)]
cpp-common/bt2: add and use `bt2::internal::Dep*` type alias templates
Those new templates take care of using `std::conditional` instead of
having to use it at each site. The template parameters of
`bt2::internal::DepType` are:
1. What to check for constness.
2. The effective type if `LibObjT` is NOT `const`.
3. The effective type if `LibObjT` is `const`.
Other `bt2::internal::Dep*` reuse `DepType` with specific types for
parameters 2 and 3 for common uses.
For example:
using UserAttributes =
typename std::conditional<std::is_const<LibObjT>::value,
ConstMapValue,
MapValue>::type;
gets replaced by:
using UserAttributes = internal::DepUserAttrs<LibObjT>;
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I434b9ae82d170c6fe8359488e78c0e3e34a064cd
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11234
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Sat, 11 Nov 2023 03:36:09 +0000 (22:36 -0500)]
cpp-common/bt2: use more specific static assertion messages
The current
`LibObjT` must NOT be `const`.
static assertion message is pretty generic. For a typical
`bt2::ConstXyz` user, `LibObjT` actually means nothing, because she's
not using `bt2::CommonXyz` directly, only an alias.
Make the message specific, for example:
Not available with `bt2::ConstBoolValue`.
For example, with:
void lel(bt2::ConstBoolValue val)
{
val = false;
}
I get:
cpp-common/bt2/value.hpp: In instantiation of ‘bt2::CommonBoolValue<LibObjT>& bt2::CommonBoolValue<LibObjT>::operator=(Value) const [with LibObjT = const bt_value; Value = bool]’:
test.cpp:61:11: required from here
cpp-common/bt2/value.hpp:349:48: error: static assertion failed: Not available with `bt2::ConstBoolValue`.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I4e96d4dcd1cc345d8b393aea6bb78fbc0000e9ba
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11361
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Fri, 3 Nov 2023 17:26:55 +0000 (13:26 -0400)]
cpp-common/bt2: add asConst() methods
Add many asConst() methods to get the `bt2::ConstXyz` version of a
`bt2::Xyz` wrapper instead of using the constructor directly.
Just some sugar.
For example:
void f(const bt2::Value val) {
{
const auto cVal = val.asConst();
// Operate on `cVal`
}
}
I only added those methods where it was easy to do so.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: Iabd9d6266fe75f33f2008c2320444624b842d9d2
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11232
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Fri, 3 Nov 2023 16:03:02 +0000 (12:03 -0400)]
cpp-common/bt2: use the "length" term everywhere instead of "size"
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I25ce7709679d016dff6b23aa323a0ca5ec738190
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11231
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Fri, 3 Nov 2023 15:56:49 +0000 (11:56 -0400)]
cpp-common/bt2: remove useless friend classes to access libObjPtr()
Mr. Deslauriers made bt2::BorrowedObj::libObjPtr() public in
341a67c45
("cpp-common: Expose BorrowedObj::libObjPtr() as public method").
Therefore, all those friend classes aren't needed anymore.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: Ie37bfa78e4cd29dd8e08af135ff6a0e597ebd0ae
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11230
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Fri, 3 Nov 2023 15:50:52 +0000 (11:50 -0400)]
cpp-common/bt2: add `noexcept` to user attribute setters
The bt_*_set_user_attributes() functions never fail (they only increment
the reference count of the received value), therefore the user attribute
setters never throw.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I5b9c05e6efd7b42965b9e075438b518df1a5da90
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11229
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Fri, 3 Nov 2023 15:32:49 +0000 (11:32 -0400)]
cpp-common/bt2: systematize the `const` method situation
This patch attempts to systematize the `const` situation regarding
methods (member functions and operators).
The current issue is that, because those wrappers are expected to be
passed and returned by copy (they only wrap a libbabeltrace2 pointer),
one cannot rely on the `const` qualifier to ensure immutability at the
library level. For example:
void f(const bt2::ArrayValue val)
{
// Want to modify what `val` wraps? No problem:
auto newVal = val;
newVal += 23;
}
The signature of f() here doesn't guarantee to the caller that what
`val` wraps is immutable. To achieve this, it needs to accept the
`Const` version of the wrapper:
void f(bt2::ConstArrayValue val)
{
// Now there's no way to modify what `val` wraps
}
Therefore, since using the `const` keyword is so fragile, this patch
makes `const` (almost) all the methods of wrapper classes: those methods
do not modify the wrapped pointer value, therefore they may be `const`.
This makes the wrapping system have this correspondence:
bt_xyz * bt2::Xyz
bt_xyz * const const bt2::Xyz
const bt_xyz * bt2::ConstXyz
const bt_xyz * const const bt2::ConstXyz
Because there were many overloads to return a `bt2::Const*` instance
when the object is `const`, this patch removes a lot of code, with the
added benefit of reducing code duplication.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: Ie633e7e9d67a8eb0138800ad8ae14c8d9bd0ca4c
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11228
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Wed, 1 Nov 2023 20:53:54 +0000 (16:53 -0400)]
cpp-common/bt2: add missing `noexcept` to static methods
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I3737dc68a270446e9eafee23afb24fc816ca2bbc
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11193
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Fri, 27 Oct 2023 18:52:32 +0000 (14:52 -0400)]
cpp-common/bt2: rename `common-iter.hpp` to `common-iterator.hpp`
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I4816ab3ecf2b19423f8ab0a92924e62c438df4f9
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11164
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Fri, 27 Oct 2023 18:35:02 +0000 (14:35 -0400)]
cpp-common/bt2: remove superfluous NL
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I96252e134bb355e2e1b0b43cf4f13a13b5ed4c7e
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11163
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Fri, 27 Oct 2023 18:33:40 +0000 (14:33 -0400)]
cpp-common/bt2/common-iter.hpp: add missing NL
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I57b2b54a5181e1cee90cd9090d349bf058e9025b
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11162
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Mon, 13 Nov 2023 19:49:26 +0000 (14:49 -0500)]
cpp-common/bt2: rename `bt2::SharedObj` -> `bt2::SharedObject`
This is public now, so use the full name without abbreviation like
everything else does.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I1328a9c195061558ca442aed6e177ca43836b99c
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11368
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Mon, 13 Nov 2023 18:52:39 +0000 (13:52 -0500)]
cpp-common/bt2: `bt2::internal::SharedObj` -> `bt2::SharedObj`
`SharedObj` is not completely internal: it offers public methods,
including creation methods.
Also, we don't need to hide anything from the end user in this file.
Therefore make this class not internal.
Also apply to specific shared object aliases, for example
`bt2::SharedValue`.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I8bf1718a95de87b7c506ffab4868e63bc57a7391
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11367
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Mon, 13 Nov 2023 19:15:33 +0000 (14:15 -0500)]
cpp-common/bt2: rename `bt2::BorrowedObj` -> `bt2::BorrowedObject`
This is public now, so use the full name without abbreviation like
everything else does.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I9716e1c5b60a06211f2292e71df574a2924e862f
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11366
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Simon Marchi [Mon, 11 Dec 2023 20:03:04 +0000 (15:03 -0500)]
cpp-common/bt2: `bt2::internal::BorrowedObj` -> `bt2::BorrowedObj`
`BorrowedObj` is not completely internal: it has public methods which
any concrete borrowed object inherits.
Also, we don't need to hide anything from the end user in this file.
Therefore make this base class not internal.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: Ib3a396a1aa7794608a4ec938f9b141c553e36c97
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11365
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Mon, 13 Nov 2023 19:55:13 +0000 (14:55 -0500)]
cpp-common/bt2/borrowed-obj.hpp: remove unused `SharedObj` forward decl.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I59f9cdd1bfd98bd4e37b4045b4ecf0dbda5b222d
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11364
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Simon Marchi [Mon, 11 Dec 2023 18:59:38 +0000 (13:59 -0500)]
Add IWYU keep pragmas when including some compat headers
When editing some on Linux, IWYU and clangd report some inclusions of
`compat/endian.h`, for instance, as unused. This is because this
header defines some macros only on systems that lack them, and Linux
isn't one of them. These includes should not be removed, so add some
pragmas to let tools (and even humans) know that they are important.
Change-Id: Id2cba11a568567e6a75d094df3567b0847dac690
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11518
Tested-by: jenkins <jenkins@lttng.org>
Simon Marchi [Sun, 10 Dec 2023 04:35:00 +0000 (23:35 -0500)]
Add some includes in C++ header files
Add some includes to fix errors shown by clangd when editing header
files. These don't fix compilation errors.
Change-Id: I1792b50c5808d9a9c3f045decea97745aac6a77f
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11496
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 7 Dec 2023 21:54:24 +0000 (21:54 +0000)]
Remove some unused includes in C++ files
Remove some unused include files. This was done partly looking at
"unused-includes" warnings from clangd in my IDE, and partly with
include-what-you-use.
Whenever needed, add some includes to keep things compiling (where
some header files relied on previous inclusions).
Change-Id: I0bca7aba4c172a13474a76b08e4a0b543e152733
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11493
Tested-by: jenkins <jenkins@lttng.org>
Simon Marchi [Thu, 7 Dec 2023 22:08:22 +0000 (22:08 +0000)]
include: add IWYU pragmas in private header files
Add Include What You Use "private" pragmas in the private header files
exported by babeltrace 2, indicating that <babeltrace2/babeltrace.h>
should be used instead.
Change-Id: I7b7bdde4ab52012b4b57d5c7739e7910a5321f9c
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11491
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 7 Dec 2023 21:53:12 +0000 (21:53 +0000)]
Remove stdbool.h includes from C++ files
This header is unnecessary in C++.
Change-Id: I4d3cbacc4805630181536069406d6eb8daded38f
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11490
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Wed, 29 Nov 2023 15:48:40 +0000 (10:48 -0500)]
Sort includes in C++ files
Set the `SortIncludes` option of clang-format to `Regroup`, meaning that
it will group include statements based on the categories in
`IncludeCategories`.
In `IncludeCategories`, define categories such that the groups are (in
order of priority):
1. C++ system headers
2. C system headers
3. Babeltrace 2 public headers
4. Logging headers (logging/log.h, as well as other header files
including it): it might be important for these files to stay at the
top, in case there is some logging in header files, so that things
like log tags are properly set.
5 Internal common headers (e.g. from common, cpp-common, compat,
logging)
6. Plugin common files (from plugins/common)
7. Local headers
8. tap/tap.h: it defines macros with common names, such as `ok` and
`fail`, which may clash with identifiers in other headers. It's
safer to keep it last.
Includes in files parser.ypp and lexer.lpp were sorted by hand. Due to
the change in inclusion order, parser.hpp (generated from parser.ypp)
did not see the definition of yyscan_t anymore. Add an inclusion of
scanner.hpp in the `%code requires` section, which ends up in both the
generated .cpp and .hpp files.
Change-Id: I0568167065b90070ac03ea4daf4d0a1927bec4b5
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11459
Tested-by: jenkins <jenkins@lttng.org>
Simon Marchi [Wed, 29 Nov 2023 15:47:03 +0000 (10:47 -0500)]
tests: normalize inclusions of tap/tap.h
Use "tap/tap.h" instead of <tap/tap.h> everywhere.
Move the inclusion at the end of the inclusion list everywhere. tap.h
defines macros with common names like `ok` and `fail`, which can clash
if defined before including other files. Let's establish the practice
of including tap.h last.
Change-Id: Ic06f59d146390d6fe21a6ac229972df02ce8d762
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11461
Tested-by: jenkins <jenkins@lttng.org>
Simon Marchi [Tue, 28 Nov 2023 20:40:47 +0000 (15:40 -0500)]
Remove unnecessary inclusions of "internal public" headers
I believe that these spots don't really need to include files from
babeltrace2 other than babeltrace.h. In fact, given the presence of:
#ifndef __BT_IN_BABELTRACE_H
# error "Please include <babeltrace2/babeltrace.h> instead."
#endif
in those "internal public" header files and the fact that the including
files don't define __BT_IN_BABELTRACE_H, I believe that those inclusions
don't have an effect. It must be that the included file was already
included earlier, as part of babeltrace.h.
Change-Id: I9f88123f12f916dea8c90641dd7b32c531f5c707
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11458
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Fri, 10 Nov 2023 20:26:15 +0000 (20:26 +0000)]
lib: validate iterator message sequence
Validate that the sequence of messages produced by iterators respects
the sequence defined by the Message Interchange Protocol (MIP) [1].
Without packets
SB (E | DE)* SE
With packets
SB ((PB (E | DE)* PE) | DE | DP)* SE
Validate that when an iterator returns
BT_MESSAGE_ITERATOR_CLASS_NEXT_METHOD_STATUS_END, all streams are
properly ended (we have received a stream end message for all streams).
Add an expected_msg_types field to the iterator's per_stream_state
structure, which holds a bit mask of the message types the iterator is
allowed to emit next.
Use the cur_packet field that is maintained by
message_packet_is_valid when processing a discarded events message. We
need to know if we are in a packet or not to determine the following
valid message types (DE appears twice in the "With packets" sequence
above, once within a packet and once outside a packet).
It doesn't matter in which order the two assertions are placed, since
the "sequence is as expected" assertion doesn't use the cur_packet field
when handling the "packet beginning" and "packet end" messages.
However, I think that it is more useful to have the "sequence is as
expected" first. Some mistakes, like the following sequence where a
packet beginning message is forgotten:
... PB E E PE E E PE ...
... would cause both assertions to fail. But the "sequence is as
expected" assertion points closer to the root cause of the problem than
the "packet is expected" one, which points more to a symptom. So, if
both assertions would fail, I prefer that we show the "sequence is
as expected" one.
Here's an example of the error message that is printed when an error is
detected. In this case, a packet beginning message was forgotten.
Babeltrace 2 library postcondition not satisfied.
------------------------------------------------------------------------
Condition ID: `post:message-iterator-class-next-method:mip-message-sequence-is-expected`.
Function: bt_message_iterator_class_next_method().
------------------------------------------------------------------------
Error is:
MIP message sequence is not expected: stream-addr=0x60d000001d80, stream-id=0, iterator-addr=0x611000004c80, iterator-upstream-comp-name="source.gpx.GpxSource", iterator-upstream-comp-log-level=WARNING, iterator-upstream-comp-class-type=SOURCE, iterator-upstream-comp-class-name="GpxSource", iterator-upstream-comp-class-partial-descr="", message-addr=0x607000004540, message-type=EVENT, expected-msg-types=STREAM_END|PACKET_BEGINNING
Aborting...
[1] https://babeltrace.org/docs/v2.0/libbabeltrace2/group__api-msg.html#api-msg-seq
Change-Id: I25d3ff9b87c551dcced1ba25e0a8525f316a8050
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/10450
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 22 Jun 2023 19:52:41 +0000 (15:52 -0400)]
lib: validate iterator message packets
Validate that messages coming out of iterators have sensible packet
values. This applies to event and packet end messages: their packet
must match the packet of the previous packet beginning message.
Add a hash table to hold per-stream state, inside the
bt_message_iterator structure. Since this state will only be used for
dev assertions, for the moment, only create it if BT_DEV_MODE is
defined.
Discard the per-stream state when the iterator seeks (after which the
iterator is expected to produce a new message sequence, starting from
scratch).
If the iterator uses auto-seek to implement "seek ns from origin", we
need to discard the per-stream state twice: once after seeking the
beginning, and once after consuming messages until the desired point.
When a wrong packet is detected, print an error logging message with
some details, before the failed assertion message:
Babeltrace 2 library postcondition not satisfied.
------------------------------------------------------------------------
Condition ID: `post:message-iterator-class-next-method:message-packet-is-expected`.
Function: bt_message_iterator_class_next_method().
------------------------------------------------------------------------
Error is:
Message's packet is not expected: stream-addr=0x60d000001d80, stream-id=0, iterator-addr=0x611000004c80, iterator-upstream-comp-name="source.gpx.GpxSource", iterator-upstream-comp-log-level=WARNING, iterator-upstream-comp-class-type=SOURCE, iterator-upstream-comp-class-name="GpxSource", iterator-upstream-comp-class-partial-descr="", message-addr=0x607000004540, message-type=EVENT, received-packet-addr=0x607000004310, expected-packet-addr=(nil)
Aborting...
The particular structure of the code is explained by the following
patch, which adds verification that the message sequence is as expected.
Both assertions (packet is expected, and message sequence is as
expected) need to know about the current packet (this state is
maintained by message_packet_is_valid), so must be in the same "for all
messages" loop. Alternatively, they could both track the current packet
independently, but that would be redundant.
But this form also allows putting more info about the problematic
message in the abort notice, which I think is nice.
Change-Id: I176417d9ae7b04a9c16ff975e008e208b173e3d2
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/10448
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Philippe Proulx [Tue, 14 Nov 2023 16:10:30 +0000 (11:10 -0500)]
Fix REUSE licensing/copyright issues in `tests/utils`
This patch makes `reuse lint` happy for the files in `tests/utils`.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I472089852d8840653c0a4a2350a4d4981329f43e
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11385
Tested-by: jenkins <jenkins@lttng.org>
CI-Build: Michael Jeanson <mjeanson@efficios.com>
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Philippe Proulx [Tue, 14 Nov 2023 16:07:26 +0000 (11:07 -0500)]
Fix REUSE licensing/copyright issues in `src`
This patch makes `reuse lint` happy for the files in `src`.
Putting the info into a separate `.license` file for
`src/cpp-common/optional.hpp` to avoid modifying the original file which
comes from an external project.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I073afa1b5de0906f4f9f2a809ef387c05833ca17
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11384
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Philippe Proulx [Tue, 14 Nov 2023 16:03:38 +0000 (11:03 -0500)]
Add SPDX info for `tests/utils/python/typing/typing.py`
Putting the info in a separate `.license` file to avoid modifying the
original one (which comes from the CPython project).
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: If183d9662f239da27a00b7f8ba8887eaec489270
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11383
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Philippe Proulx [Tue, 14 Nov 2023 15:58:11 +0000 (10:58 -0500)]
Add SPDX info to Python bindings documentation
The text and images have the `CC-BY-SA-4.0` license.
`LICENSES/CC-BY-SA-4.0.txt` already exists, but wasn't used.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I66428778d69cc4b44816cb6588283984d16f3d78
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11382
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Philippe Proulx [Tue, 14 Nov 2023 15:56:56 +0000 (10:56 -0500)]
Add missing REUSE licenses
`reuse lint` says:
# MISSING LICENSES
'FSFAP' found in:
* m4/ax_append_compile_flags.m4
* m4/ax_append_flag.m4
* m4/ax_check_compile_flag.m4
* m4/ax_cxx_compile_stdcxx.m4
* m4/ax_require_defined.m4
'FSFULLR' found in:
* m4/ae_python_modules.m4
'GPL-2.0-or-later' found in:
* m4/ax_c___attribute__.m4
* m4/ax_pthread.m4
* tests/utils/tap-driver.sh
'LicenseRef-Autoconf-exception-macro' found in:
* m4/ax_c___attribute__.m4
* m4/ax_pthread.m4
Download and add them.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I71576e2ed2281a1890a49a5cb9261c11fe30706e
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11381
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Philippe Proulx [Tue, 14 Nov 2023 15:51:21 +0000 (10:51 -0500)]
LICENSES: add `.txt` extension to license files
`reuse lint` says:
# LICENSES WITHOUT FILE EXTENSION
The following licenses have no file extension:
* BSD-2-Clause
* BSD-4-Clause
* BSL-1.0
* CC-BY-SA-4.0
* GPL-2.0-only
* GPL-3.0-or-later
* LGPL-2.1-only
* MIT
* PSF-2.0
Make it happy.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I6c06d74c37fe4230e5c302783183211eeff2b8a5
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11379
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Tested-by: jenkins <jenkins@lttng.org>
CI-Build: Michael Jeanson <mjeanson@efficios.com>
Philippe Proulx [Tue, 14 Nov 2023 15:48:49 +0000 (10:48 -0500)]
Use `LICENSES/GPL-3.0-or-later` (`GPL-3.0` is deprecated)
As of this date, the SPDX website says [1] about "GNU General Public
License v3.0 only":
> This license identifier has been deprecated since license list
> version 3.0.
Therefore, use `GPL-3.0-or-later`.
That's already the short ID we use in `tests/utils/tap/tap.sh`, not
`GPL-3.0`.
[1]: https://spdx.org/licenses/GPL-3.0.html
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I72349b1631cabfa16a59e0228871205978d5dd91
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11378
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Tested-by: jenkins <jenkins@lttng.org>
Philippe Proulx [Tue, 14 Nov 2023 15:44:39 +0000 (10:44 -0500)]
Use `LICENSES/GPL-2.0-only` (`GPL-2.0` is deprecated)
As of this date, the SPDX website says [1] about "GNU General Public
License v2.0 only":
> This license identifier has been deprecated since license list
> version 3.0.
Therefore, use `GPL-2.0-only`.
That's already the short ID we use everywhere, not `GPL-2.0`.
[1]: https://spdx.org/licenses/GPL-2.0.html
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: Ifa073ef2a833f5bc6fb1051d50146ca352965688
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11377
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Philippe Proulx [Tue, 14 Nov 2023 15:38:30 +0000 (10:38 -0500)]
Use `LICENSES/LGPL-2.1-only` (`LGPL-2.1` is deprecated)
As of this date, the SPDX website says [1] about "GNU Lesser General
Public License v2.1 only":
> This license identifier has been deprecated since license list
> version 3.0.
Therefore, use `LGPL-2.1-only`.
That's already the short ID we use in `src/common/list.h`.
[1]: https://spdx.org/licenses/LGPL-2.1.html
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I2a6193f9b9b03275505424ecebc9896d9faabb0e
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11376
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Philippe Proulx [Tue, 14 Nov 2023 15:23:35 +0000 (10:23 -0500)]
Remove `src/plugins/ctf/common/bfcr/btr.gdb`
We don't use nor maintain that. I'm not even sure what it does. We used
it mostly while developing Babeltrace 2.0, but things are stable now.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I3ced5c5e57ee55013820cac77cdb456f3f984b0a
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11375
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Philippe Proulx [Tue, 14 Nov 2023 14:54:35 +0000 (09:54 -0500)]
tests/utils/python/normand.py: add SPDX headers
This is still the file as is from the upstream project.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: Ide3014910bd169f7fdaf05e2bbafd517a6ff6a93
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11374
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Simon Marchi [Mon, 6 Nov 2023 19:54:36 +0000 (19:54 +0000)]
tools: add lint-py.sh
Add lint-py.sh, running the various static analysis tools we use for
Python.
Change-Id: I6ccd5f7fb484506a0f936d7fe276042cccd186a6
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11269
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Mon, 6 Nov 2023 19:40:56 +0000 (19:40 +0000)]
Re-format C++ files
The last few commits introduced some formatting errors, re-formating
using `tools/format-cpp`.
Change-Id: Ib9e4075d52b95f505bc6cbe2a2d5cd70d6926f84
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11268
CI-Build: Philippe Proulx <eeppeliteloop@gmail.com>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Tested-by: jenkins <jenkins@lttng.org>
Simon Marchi [Mon, 6 Nov 2023 18:41:38 +0000 (18:41 +0000)]
tests: add and use bt_grep_ok
When a test that consists of matching a pattern in a file using grep
fails (sometimes just in the CI), it would be useful to see the file
contents to understand what happened. Add the `bt_grep_ok` utility
function. It tries to match a pattern in a file using `grep`, then
issues a test result. If the test failed, it prints the content of the
file on stderr.
Change-Id: I464e414b334052677799ce201483095fa9bff4c3
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11169
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Tested-by: jenkins <jenkins@lttng.org>
Simon Marchi [Mon, 6 Nov 2023 18:36:59 +0000 (18:36 +0000)]
tests: add and use bt_grep
Add the `bt_grep` function, which passes all its arguments to the grep
binary specified by BT_TESTS_GREP_BIN. Use everywhere where applicable
in the testsuite.
Change-Id: Ia166106fd85312e681fa2692e1f5409c9556f897
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11248
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
CI-Build: Michael Jeanson <mjeanson@efficios.com>
Simon Marchi [Tue, 7 Nov 2023 16:48:12 +0000 (16:48 +0000)]
build: move common headers to common_libcommon_la_SOURCES
Since we have an libcommon convenience library, I think it would make
sense to put all common headers there, instead of in noinst_HEADERS.
Change-Id: I161e5dc234c46599efbaffcea4e759e2df0ffc96
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11291
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Simon Marchi [Thu, 2 Nov 2023 19:54:18 +0000 (19:54 +0000)]
filter.utils.trimmer: remove unused parameter from set_bound_from_param
Change-Id: I17e3a3cb7542c292f7eaa5e349725e2dca664abc
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11217
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 2 Nov 2023 19:52:55 +0000 (19:52 +0000)]
sink.text.details: remove unused parameter from configure_bool_opt
Change-Id: I71601439e92bdd678b45731f7f08a7c4d59f66eb
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11216
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 2 Nov 2023 19:51:08 +0000 (19:51 +0000)]
flt.lttng-utils.debug-info: remove unused parameter from handle_msg_iterator_inactivity
Change-Id: I007b1d2a121ce1cf15abffda7485aaa396c3c7b2
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11215
CI-Build: Simon Marchi <simon.marchi@efficios.com>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 2 Nov 2023 19:50:22 +0000 (19:50 +0000)]
src.ctf.lttng-live: remove unused parameter from lttng_live_metadata_create_stream
Change-Id: Id70429d549c25aca07e6b6819e0f6f0a5fe01e4d
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11214
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 2 Nov 2023 19:49:33 +0000 (19:49 +0000)]
src.ctf.lttng-live: remove unused parameter from live_get_msg_ts_ns
Change-Id: I5cd8569817f83b080af0ca0ff9fdb9218d3f5b13
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11213
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 2 Nov 2023 19:48:41 +0000 (19:48 +0000)]
src.ctf.fs: remove parameter from create_one_port_for_trace
Change-Id: Ia58cc038ba597dff3c5e2fc6d9d29e18f71d5c89
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11212
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 2 Nov 2023 19:47:53 +0000 (19:47 +0000)]
src.ctf.fs: remove unused parameter from ctf_fs_component_create
Change-Id: I32ed8d398a1292a48ebccb27578dee9e20d3b4f3
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11211
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 2 Nov 2023 19:46:15 +0000 (19:46 +0000)]
sink.ctf.fs: remove unused parameter from append_string_field_class
Change-Id: I262bcd035bdbdc81b80c80dc74f8ca9aebf5af34
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11210
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 2 Nov 2023 19:45:27 +0000 (19:45 +0000)]
sink.ctf.fs: remove unused parameter from write_string_field
Change-Id: I5098245393516b4a37daae1d0c0fe37fcf9bb2f5
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11209
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 2 Nov 2023 19:43:49 +0000 (19:43 +0000)]
lib: remove unused parameter from set_integer_value
Change-Id: I6334e430afce5170908f28a2d579806f87eff860
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11208
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 2 Nov 2023 19:42:19 +0000 (19:42 +0000)]
lib: remove unused parameters bt_util_ns_from_origin_inline
Change-Id: I54bb5b1677f9e5761cb9e394d25706086f1a38ec
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11207
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 2 Nov 2023 19:36:11 +0000 (19:36 +0000)]
lib: remove `extended` parameters from format_* functions
Change-Id: Iad81577eebfc0306afbaf6b15b8f7ad398a84959
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11206
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 2 Nov 2023 19:33:18 +0000 (19:33 +0000)]
lib: remove unused internal component destroy functions
These destroy functions are empty, remove them. They can always be
added back later if needed, but I don't see the value in keeping then
"just in case".
Change-Id: I5845d2834294583367c85a840b016a536bf0b120
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11205
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 2 Nov 2023 19:26:00 +0000 (19:26 +0000)]
compat: remove unused `addr` parameter from bt_mmap
Change-Id: Iecf7764f5fd669369064aa3b3fafe2575d933f28
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11204
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Michael Jeanson [Thu, 2 Nov 2023 18:49:18 +0000 (14:49 -0400)]
Reduce the number of Makefiles in 'src/' by one more
The libcommon Makefile was the only one left of the convenience library
Makefiles to ensure that the version header was generated before the
other libraries were built.
By using the 'BUILT_SOURCES' variable we can ensure that 'version.i' is
generated first and merge this in 'src/Makefile'.
Change-Id: I0a6510af65674d1c8bb6a3a08d9a10b07e00fdd7
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11203
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Tested-by: jenkins <jenkins@lttng.org>
Simon Marchi [Thu, 2 Nov 2023 16:06:46 +0000 (12:06 -0400)]
lib: remove unused parameters in internal component creation functions
I noticed that these 3 functions didn't use the `class` parameter,
remove it.
Change-Id: I34b798dfbd8b1e54e7ddf633b61d6d205c0132cb
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/10408
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Tested-by: jenkins <jenkins@lttng.org>
Michael Jeanson [Tue, 31 Oct 2023 19:26:15 +0000 (15:26 -0400)]
Reduce the number of Makefiles in 'src/' even MOAR!
Change-Id: I3dbb16250f62513ba131592c596fbaaf1ba97ffe
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11192
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 22 Jun 2023 13:42:17 +0000 (09:42 -0400)]
doc: fix passing non-event messages in distill examples
The distill filter example means to let non-event messages go through,
but it actually drops them. Fix it so it actually lets them through.
Verified by sending the output of the filter to `sink.text.details`.
Before the patch, there is no stream beginning message. After the
patch, there is.
Change-Id: I2414a37ca7fc5fa6e5ed0fe179ee39cadf261f31
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/10444
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Michael Jeanson [Wed, 9 Mar 2022 22:52:21 +0000 (17:52 -0500)]
configure: re-enable '-Wunused-parameter'
This warning is part of '-Wextra' in GCC.
Change-Id: Ifb514a41cb9c62cf703d415eeb2ccefc331dee77
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/7559
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Michael Jeanson [Wed, 9 Mar 2022 22:14:20 +0000 (17:14 -0500)]
configure: re-enable '-Wmissing-field-initializers'
This warning is part of '-Wextra' in GCC.
Change-Id: Ie6170cb06900e93011ddedc102a9964c63edad55
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/7558
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Simon Marchi [Sun, 7 Jun 2020 22:54:29 +0000 (18:54 -0400)]
Fix: tests: conditionally skip Python bindings test that requires Python plugins support
As exposed by bug 1272 [1], there are some tests in
test_trace_collection_message_iterator.py that depend on Python plugins
being enabled. Running the tests with `--enable-python-bindings` and
`--disable-python-plugins` therefore leads to these tests failing.
Fix it by skipping them if the support for Python plugins is not
enabled.
[1] https://bugs.lttng.org/issues/1272
Change-Id: I4881a3b0a336b9078715837cb7f8f423bbc2b982
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/3621
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
CI-Build: Michael Jeanson <mjeanson@efficios.com>
Simon Marchi [Fri, 27 Oct 2023 20:27:07 +0000 (20:27 +0000)]
tests: remove test dir in test-query-metadata-info.sh
Change-Id: Ib3415ae8370bec53d0eb1ffa807f011b6b0c933c
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11182
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Mon, 30 Oct 2023 15:35:41 +0000 (11:35 -0400)]
Fix: tests: use local typing.py for Python 3.5
`typing.NoReturn` was introduced in Python 3.5.4. Therefore, there are
releases of Python 3.5 with which we get errors like:
# Running: python3 /home/smarchi/src/babeltrace/tests/utils/python/mctf.py --base-dir /tmp/test-stored-value.jJOHoog/stored-values /home/smarchi/src/babeltrace/tests/data/ctf-traces/live/stored-values.mctf
Traceback (most recent call last):
File "/home/smarchi/src/babeltrace/tests/utils/python/mctf.py", line 13, in <module>
import normand
File "/home/smarchi/src/babeltrace/tests/utils/python/normand.py", line 61, in <module>
from typing import Any, Set, Dict, List, Union, Pattern, Callable, NoReturn, Optional
ImportError: cannot import name 'NoReturn'
Fix that by using our local typing module for Python 3.5.
Change-Id: I5660a5e0e2014a71c5e6b98b6ce1970b5bb1226e
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11172
CI-Build: Michael Jeanson <mjeanson@efficios.com>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Tested-by: jenkins <jenkins@lttng.org>
Simon Marchi [Mon, 30 Oct 2023 15:30:29 +0000 (11:30 -0400)]
Fix: tests: use run_python in gen_mctf_trace
gen_mctf_trace calls the python3 interpreter, without using the
`run_python` wrapper. PYTHONPATH is therefore not set appropriately
for Python to find our local `typing.py` module, if needed.
Add a call to `run_python` to fix that.
Change-Id: Id813169905d511e5600a70cebad681b00ebb49d8
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11171
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
CI-Build: Michael Jeanson <mjeanson@efficios.com>
Tested-by: jenkins <jenkins@lttng.org>
Simon Marchi [Mon, 30 Oct 2023 18:38:57 +0000 (14:38 -0400)]
tests: retry os.rename on PermissionError failure in lttng_live_server.py
On the Windows CI jobs, we get random failures like:
# plugins/src.ctf.lttng-live/test-live.sh: python3 /c/Users/jenkins/workspace/dev_review_babeltrace_master_winbuild/build/std/conf/std/platform/msys2-mingw64/src/babeltrace/tests/data/plugins/src.ctf.lttng-live/lttng_live_server.py /c/Users/jenkins/workspace/dev_review_babeltrace_master_winbuild/build/std/conf/std/platform/msys2-mingw64/src/babeltrace/tests/data/plugins/src.ctf.lttng-live/inactivity-discarded-packet.json --port-file /c/Users/jenkins/workspace/dev_review_babeltrace_master_winbuild/build/std/conf/std/platform/msys2-mingw64/tmp/test-live-server-port.Rn2dyS --trace-path-prefix C:\Users\jenkins\workspace\dev_review_babeltrace_master_winbuild\build\std\conf\std\platform\msys2-mingw64\src\babeltrace\tests\data\ctf-traces
Traceback (most recent call last):
File "C:/Users/jenkins/workspace/dev_review_babeltrace_master_winbuild/build/std/conf/std/platform/msys2-mingw64/src/babeltrace/tests/data/plugins/src.ctf.lttng-live/lttng_live_server.py", line 1951, in <module>
LttngLiveServer(port, port_filename, sessions, max_query_data_response_size)
File "C:/Users/jenkins/workspace/dev_review_babeltrace_master_winbuild/build/std/conf/std/platform/msys2-mingw64/src/babeltrace/tests/data/plugins/src.ctf.lttng-live/lttng_live_server.py", line 1667, in __init__
self._write_port_to_file(port_filename)
File "C:/Users/jenkins/workspace/dev_review_babeltrace_master_winbuild/build/std/conf/std/platform/msys2-mingw64/src/babeltrace/tests/data/plugins/src.ctf.lttng-live/lttng_live_server.py", line 1792, in _write_port_to_file
os.replace(tmp_port_file.name, port_filename)
PermissionError: [WinError 5] Access is denied: 'C:/Users/jenkins/workspace/dev_review_babeltrace_master_winbuild/build/std/conf/std/platform/msys2-mingw64/tmp/tmpt13jh6sp' -> 'C:/Users/jenkins/workspace/dev_review_babeltrace_master_winbuild/build/std/conf/std/platform/msys2-mingw64/tmp/test-live-server-port.Rn2dyS'
The PermissionError exception is raised when trying to move the port
file from its temporary location to its final location, where the bash
script expects it to appear.
I don't understand the root cause of the issue. When exiting the `with`
scope, the temporary file is supposed to be closed, and it should be
fine to move it. I suppose it's possible that something in the Windows
kernel hasn't completely finished using the file when we try to move it.
Implement a wait-and-retry scheme as a (bad) workaround.
Change-Id: Ia8dcefca9538aa5e58438bf84a3fa67e5e05a49a
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11174
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Michael Jeanson [Mon, 30 Oct 2023 19:06:27 +0000 (15:06 -0400)]
cleanup: tests: remove unused files from lf / crlf traces
Change-Id: I259bd6a88f48d00471bd6a779d0e15150d4c3d4e
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11175
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Tested-by: jenkins <jenkins@lttng.org>
Philippe Proulx [Mon, 30 Oct 2023 18:12:41 +0000 (14:12 -0400)]
tools/format-cpp: add `.sh` extension to identify it
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: Ifb57e0a26a4d7a2da99bd74fdf24d8aadcec4cf6
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11173
Philippe Proulx [Thu, 26 Oct 2023 15:36:56 +0000 (11:36 -0400)]
tools/format-cpp: exclude generated `parser.*` and `lexer.*` files
We don't need to format them because they're not tracked.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I0df8ffe9cef64b62b9327ee05acc2f4c5d48401b
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11150
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Thu, 26 Oct 2023 13:25:16 +0000 (09:25 -0400)]
tools/format-cpp: accept optional starting directory
This patch makes `tools/format-cpp` accept an optional starting
directory (instead of the root directory of the project) as its first
argument:
$ pwd
/home/dboucher/Mes Logiciels/babeltrace/src/plugins/ctf
$ ../../../tools/format-cpp .
clang-format -i /home/eepp/dev/babeltrace/src/plugins/ctf/fs-src/fs.cpp
clang-format -i /home/eepp/dev/babeltrace/src/plugins/ctf/fs-src/file.cpp
clang-format -i /home/eepp/dev/babeltrace/src/plugins/ctf/fs-src/query.cpp
...
clang-format -i /home/eepp/dev/babeltrace/src/plugins/ctf/lttng-live/metadata.hpp
clang-format -i /home/eepp/dev/babeltrace/src/plugins/ctf/lttng-live/data-stream.hpp
Using realpath(1) to transform the starting directory because find(1)
will only consider file names relative to its starting point, therefore
if the starting point is `.` (and the CWD is `src/cpp-common`),
`*/src/cpp-common/optional.hpp` and so on don't match anything and the
script will format files to be excluded.
Using `-path` instead of `-wholename` which is more precise and also
seems more portable.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I46219035e9b815dffe9200bb924478e4a7b02a04
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11145
Philippe Proulx [Thu, 26 Oct 2023 13:13:44 +0000 (09:13 -0400)]
tools/format-cpp: use a group of `echo` lines with a single `>& 2`
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I4202fa48c0fe6909aeb3b1ea34870e920908917f
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11144
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Philippe Proulx [Thu, 26 Oct 2023 12:45:45 +0000 (08:45 -0400)]
tools/format-cpp: add `-t` to `xargs`
`tools/format-cpp` can be a bit long, so show the progress by making
xargs print the executed command.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: Ifb5e40017a2bb429ce7e900a2076532bc038a792
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11143
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Philippe Proulx [Thu, 26 Oct 2023 12:42:56 +0000 (08:42 -0400)]
tools/format-cpp: make shellcheck happy again
This patch:
* Checks the `version` variable assignment directly to avoid relying on
`$?`, therefore removing the `shellcheck disable` comment.
* Makes `formatter` an array to satisfy SC2086, therefore removing the
`shellcheck disable` comment.
* Quotes `$(nproc)` to satisfy SC2068.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: Ib7c5fe530faad12704ee8b91ae55a6bfcb1aee5c
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11142
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-by: Michael Jeanson <mjeanson@efficios.com>
Philippe Proulx [Sun, 29 Oct 2023 16:32:11 +0000 (12:32 -0400)]
tests: normalize names of files and more
The current naming situation is somewhat of a mess in the `tests`
directory, making it difficult to deduce (or write) a convention.
Use hyphens to separate words as much as possible, following what we
usually like for source file names (see `tree src`).
Pretty much the only things remaining with underscores are Python file
names because of the `import` constraints and because it's Python's own
convention.
Also make all shell scripts have the `.sh` extension. This makes any
worthy editor highlight the shell syntax correctly and tells you
immediately it's not a compiled ("binary") executable. I'd prefer
`.bash` for Bash code, but I don't think we need to go as far.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I43cd279d78c240a7e3686ad8afd6759bad9f575f
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11170
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
CI-Build: Simon Marchi <simon.marchi@efficios.com>
Michael Jeanson [Wed, 25 Oct 2023 20:58:53 +0000 (16:58 -0400)]
Reduce the number of Makefiles in 'doc/'
Continue the effort started by Simon to reduce the overall number of
Makefiles to allow for faster parallel builds.
Change-Id: I7a4a8543a2f1e2781f09fbe0bdea2cc0395d239d
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11156
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Michael Jeanson [Tue, 24 Oct 2023 19:18:00 +0000 (15:18 -0400)]
Reduce the number of Makefiles in 'src/'
Continue the effort started by Simon to reduce the overall number of
Makefiles to allow for faster parallel builds.
Change-Id: I3d87dea9979c09d1a6416c7b9950264a8c4d81dc
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11155
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Michael Jeanson [Tue, 24 Oct 2023 18:56:44 +0000 (14:56 -0400)]
Reduce the number of Makefiles in 'src/plugins/text'
Continue the effort started by Simon to reduce the overall number of
Makefiles to allow for faster parallel builds. Also reduce the number of
convenience libraries for faster linking.
Change-Id: I1e706eb0bb5d52d0172ab6d0773f861865562158
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11154
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Michael Jeanson [Tue, 24 Oct 2023 18:41:24 +0000 (14:41 -0400)]
Reduce the number of Makefiles in 'src/plugins/lttng-utils'
Continue the effort started by Simon to reduce the overall number of
Makefiles to allow for faster parallel builds.
Change-Id: I339d190fea78fcefd6b3927cccb89db1b4fec6f4
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11153
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Michael Jeanson [Tue, 24 Oct 2023 18:26:20 +0000 (14:26 -0400)]
Reduce the number of Makefiles in 'src/plugins/common'
Continue the effort started by Simon to reduce the overall number of
Makefiles to allow for faster parallel builds.
Change-Id: Ic90c2c4e60f0af76bb0fde784d3cb64030aa7f44
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11152
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Michael Jeanson [Tue, 24 Oct 2023 18:14:41 +0000 (14:14 -0400)]
Reduce the number of Makefiles in 'src/plugins/utils'
Continue the effort started by Simon to reduce the overall number of
Makefiles to allow for faster parallel builds. Also reduce the number of
convenience libraries for faster linking.
Change-Id: I772572c3dc1d2481ec94526a4301d4bb79f9d855
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11151
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Philippe Proulx [Thu, 26 Oct 2023 18:59:15 +0000 (14:59 -0400)]
Remove `src/cpp-tester`
This was never meant to be added.
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Change-Id: I4ba129b99145cceef6f785d07f7c84341754e827
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11157
Michael Jeanson [Mon, 17 Apr 2023 19:18:08 +0000 (15:18 -0400)]
Update autoconf archive macros
Change-Id: I899d955dd1ff53a7bde9729a13396da7514f35cc
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/10342
CI-Build: Philippe Proulx <eeppeliteloop@gmail.com>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Tested-by: jenkins <jenkins@lttng.org>
Michael Jeanson [Thu, 19 Oct 2023 17:27:30 +0000 (13:27 -0400)]
Add test to parse lf/crlf metadata
Unix-like platforms represent line endings in text file with a '\n' or
LF while Windows uses '\r\n' or CRLF. The CTF standard doesn't specify a
canonical representation for metadata files and only requires whitespace.
Test both styles of line endings on all platforms to ensure
interoperability of the produced metadata files.
Change-Id: Ib4080b1d95be2fb0d5844e7772bd6c2832de378a
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11078
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Michael Jeanson [Mon, 23 Oct 2023 20:16:34 +0000 (16:16 -0400)]
fix: tests: use a portable invocation of 'sed -i'
The GNU and BSD sed implementations slightly differ in the handling of
an argument to the '-i' switch to use as a suffix to a backup file. BSD
sed requires an argument while it's optional for GNU sed, if present it
must be placed directly after the switch with no space.
To make both implementations work properly and not create a backup file,
a zero length argument must be placed directly after the switch with no
space.
Change-Id: Ifd2cd5b27df05e3301e527ef1d8e718b434d2236
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11132
Reviewed-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Tue, 24 Oct 2023 14:39:26 +0000 (10:39 -0400)]
ctf: reduce the number of `Makefile.am`s
This should help speeding parallel builds a bit, by reducing the time
spent in directories with few source files. The time necessary to build
the intermediary .la libraries is also non-negligible (at least on
Windows), so having less of those should help.
I kept `common/metadata/Makefile.am`, because it has a lot of complexity
specific to the use of bison, I think it's good to keep it in its own
file.
Change-Id: I6b7a5ca370d6b4481bda3649ab51009e70a0e393
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11137
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Tue, 17 Oct 2023 19:33:37 +0000 (15:33 -0400)]
ctf: grow stored_values array when necessary
The CTF message iterator accesses the `stored_values` array out of
bounds in the following situation:
- In the context of a src.ctf.lttng-live source, a ctf_trace_class gets
created from some metadata.
- At this point, ctf_trace_class->stored_value_count indicates that a
certain number of stored values are necessary given the metadata
parsed up to now.
- The message iterators are created with `stored_values` arrays of that
size.
- The source receives more metadata, which requires more stored
values.
- The message iterator reads some event described by the new metadata,
that requires the use of a stored value.
- Since the stored value arrays have not been resized to reflect the
necessary number of stored value considering the new metadata, the
message iterator tries to store a value past the end of the array.
Fix this by ensuring the `stored_values` array is large enough before
storing a value in it.
Add a test with a hand-crafted trace that replicates the scenario
described in the simplest manner possible:
- send a bit of metadata
- send a bit of data that uses that metadata
- send a bit more metadata (that requires a new stored value)
- send a bit of data that uses that new metadata
Without the fix, we get (when babeltrace is built in debug mode):
(╯°□°)╯︵ ┻━┻ /home/smarchi/src/babeltrace/src/plugins/ctf/common/msg-iter/msg-iter.cpp:1865: bfcr_unsigned_int_cb(): Assertion `(uint64_t) int_fc->storing_index < msg_it->stored_values->len` failed.
... showing the out of bounds array access.
Change-Id: I78e3ca57ac6cae1959425df3c8ffdbfeb534f348
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/10866
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Tested-by: jenkins <jenkins@lttng.org>
Simon Marchi [Mon, 16 Oct 2023 18:07:03 +0000 (14:07 -0400)]
tests: add `tests/utils/python/mctf.py`, a text to CTF trace generator
Add `mctf.py`, a utility to generate a test trace from a moultipart file
(see `moultipart.py`).
Any part having the header info `metadata` is written as-is in a file
named `metadata`. Other parts are considered Normand inputs, and the
output is written to a file of which the name is the exact header info
of the part. For example:
--- metadata
/* CTF 1.8 */
[...]
--- stream0
"Normand input here"
--- .index/stream0
"Normand input here too"
Variables and labels are carried from one normand.parse()
call to the other, allowing parts to refer to variables/labels from
previous parts.
All files are written relative to the value of the `--base-dir` option,
or relative to the current working directory if omitted. Any
nonexistent parent directory is created if needed (like `make -p`).
Add a function in `utils.sh that runs `mctf.py`.
Change-Id: I345b77ac382f268e8becd553e2e301982d80ced3
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/11056
CI-Build: Simon Marchi <simon.marchi@efficios.com>
Tested-by: jenkins <jenkins@lttng.org>
Simon Marchi [Fri, 22 Sep 2023 20:43:00 +0000 (16:43 -0400)]
tests: add moultipart.py
Add moultipart.py, a Python module to help read text files meant to be
split in different parts. A moultipart-compliant file is a succession
of parts, where each part is made of a header line followed with zero or
more lines of content.
A header line consists of `---` optionally followed by a space and some
custom information.
The moultipart module exposes the `parse` function, which takes a TextIO
object and returns a list of Part objects.
For instance, the following input:
--- Victoria
Parenteau
---
Taillon
--- This part is empty
--- Josianne
Gervais
results in the following parts:
[Part('Victoria', 'Parenteau\n', 2),
Part('', 'Taillon\n', 4),
Part('This part is empty', '', 6),
Part('Josianne', 'Gervais\n', 7)]
Change-Id: I50fb88ed6e064c09deaf1d56187415bc26002a14
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Signed-off-by: Philippe Proulx <eeppeliteloop@gmail.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/10912
Tested-by: jenkins <jenkins@lttng.org>
Simon Marchi [Fri, 22 Sep 2023 18:59:33 +0000 (14:59 -0400)]
tests: use /dev/null instead of empty files in src.ctf.lttng-live test
Instead of creating empty files, use /dev/null.
Change-Id: I4193da1fb60e9bd25df61afde09a7684b6cdf8f7
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/10906
Tested-by: jenkins <jenkins@lttng.org>
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Simon Marchi [Thu, 5 Oct 2023 02:28:53 +0000 (22:28 -0400)]
tests: pass trace path prefix down in test_live
A future test case will need to use a different trace path prefix than
the existing tests. Add a parameter for that and pass the value down.
Change-Id: I2b95ce098461f32503cafabfc640d99fe120e582
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/10919
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Tested-by: jenkins <jenkins@lttng.org>
Simon Marchi [Wed, 18 Oct 2023 03:23:52 +0000 (23:23 -0400)]
tests: pass live server args down using arrays
Pass arguments to lttng_live_server.py all the way down using arrays.
Change-Id: I9efd02539fd7c790bb941069bceadb7b7f5315a2
Signed-off-by: Simon Marchi <simon.marchi@efficios.com>
Reviewed-on: https://review.lttng.org/c/babeltrace/+/10918
Reviewed-by: Philippe Proulx <eeppeliteloop@gmail.com>
Tested-by: jenkins <jenkins@lttng.org>
This page took 0.055624 seconds and 4 git commands to generate.