d29b89d307
This will soon replace the IntoXml trait. The idea here is that we don't generally need to take ownership of values which are going to be transformed into XML: most of the time, the XML text is created by building a string from some more specific type, such as an integer or an enum. Requiring to clone an entire structure for this purpose is wasteful. In other cases, we actually could reference data right from the structs we are converting to XML. In those cases, assuming that an iterator always generates owned data would be incorrect, too. Hence, we introduce a new `Item` type which closely mirrors the `rxml::Item` type, but where the constituents are `Cow`. In the upcoming changes, we are going to work toward replacing all uses of `IntoXml` with `AsXml`, as well as modifying the macros accordingly. |
||
---|---|---|
.forgejo/workflows | ||
jid | ||
minidom | ||
parsers | ||
sasl | ||
tokio-xmpp | ||
xmpp | ||
xso | ||
xso-proc | ||
.gitea | ||
.github | ||
.gitignore | ||
.gitlab-ci.yml | ||
Cargo.toml | ||
CODE_OF_CONDUCT.md | ||
CONTRIBUTING.md | ||
LICENSE | ||
README.md |
xmpp-rs
What's this?
A very much WIP set of rust XMPP library with the goals of being type-safe and well-tested.
xmpp-rs
provides a high-level API for the protocol. You shouldn't need to know about the protocol to use it.tokio-xmpp
is a lower-level library that handles the XMPP stream(s).xmpp-parsers
parses XML into Rust and back.minidom
is a DOM library quite specific for XMPPjid
is a Jid parsing library.
Contact
There is an XMPP MUC for the discussion of this library, feel free to join! :)
Community
A Code of Conduct is available as CODE_OF_CONDUCT.md in the repository for the well-being of the community. Please refer to it in case of a possible conflict in any of the xmpp-rs venues (channel, forge, etc.).
License
Mozilla Public License 2 (MPL2). See the LICENSE file.
Building
Dependencies should be provided by crates if you use the default features. If
you use tokio-xmpp's tls-native
feature you will need an ssl library
(openssl, libressl, etc.).
cargo build
The various features available should be explained in the crates themselves.
Contributing
Thank you for your interest in the project!
Contributing rules are available as CONTRIBUTING.md in the repository.