aboutsummaryrefslogtreecommitdiff
path: root/xmpp-vala/src/core/stanza_attribute.vala
diff options
context:
space:
mode:
authorMarvin W <git@larma.de>2017-04-18 17:53:25 +0200
committerMarvin W <git@larma.de>2017-04-18 20:20:41 +0200
commitf95b4f4e0949eefaed871c267626e3ff84ce5ca6 (patch)
treee60469776bcf062d2db15e9968bf6dbd37fa1630 /xmpp-vala/src/core/stanza_attribute.vala
parent765c2605cd0abf2b4431051142f09e2676584222 (diff)
downloaddino-f95b4f4e0949eefaed871c267626e3ff84ce5ca6.tar.gz
dino-f95b4f4e0949eefaed871c267626e3ff84ce5ca6.zip
xmpp-vala/core+libdino: concurrency + nullity improvements
Diffstat (limited to 'xmpp-vala/src/core/stanza_attribute.vala')
-rw-r--r--xmpp-vala/src/core/stanza_attribute.vala51
1 files changed, 40 insertions, 11 deletions
diff --git a/xmpp-vala/src/core/stanza_attribute.vala b/xmpp-vala/src/core/stanza_attribute.vala
index e6887f33..26e63f80 100644
--- a/xmpp-vala/src/core/stanza_attribute.vala
+++ b/xmpp-vala/src/core/stanza_attribute.vala
@@ -1,7 +1,18 @@
namespace Xmpp.Core {
+
public class StanzaAttribute : StanzaEntry {
- public StanzaAttribute() {}
+ internal const string ATTRIBUTE_STRING_FORMAT = "{%s}:%s='%s'";
+ internal const string ATTRIBUTE_STRING_NO_NS_FORMAT = "%s='%s'";
+ internal const string ATTRIBUTE_STRING_ANSI_FORMAT = ANSI_COLOR_GRAY+"{%s}:"+ANSI_COLOR_END+"%s="+ANSI_COLOR_GREEN+"'%s'"+ANSI_COLOR_END;
+ internal const string ATTRIBUTE_STRING_ANSI_NO_NS_FORMAT = "%s="+ANSI_COLOR_GREEN+"'%s'"+ANSI_COLOR_END;
+ internal const string ATTRIBUTE_XML_FORMAT = "%s:%s='%s'";
+ internal const string ATTRIBUTE_XML_NO_NS_FORMAT = "%s='%s'";
+ internal const string ATTRIBUTE_XML_ANSI_FORMAT = "%s:%s="+ANSI_COLOR_GREEN+"'%s'"+ANSI_COLOR_END;
+ internal const string ATTRIBUTE_XML_ANSI_NO_NS_FORMAT = "%s="+ANSI_COLOR_GREEN+"'%s'"+ANSI_COLOR_END;
+
+ internal StanzaAttribute() {
+ }
public StanzaAttribute.build(string ns_uri, string name, string val) {
this.ns_uri = ns_uri;
@@ -9,29 +20,47 @@ public class StanzaAttribute : StanzaEntry {
this.val = val;
}
- public string to_string() {
- if (ns_uri == null) {
- return @"$name='$val'";
+ internal string printf(string fmt, bool no_ns = false, string? ns_name = null) {
+ if (no_ns) {
+ return fmt.printf(name, (!)val);
} else {
- return @"{$ns_uri}:$name='$val'";
+ if (ns_name == null) {
+ return fmt.printf((!)ns_uri, name, (!)val);
+ } else {
+ return fmt.printf((!)ns_name, name, (!)val);
+ }
}
}
+ public string to_string() {
+ return printf(ATTRIBUTE_STRING_FORMAT);
+ }
+
public string to_ansi_string(bool hide_ns = false) {
- if (ns_uri == null || hide_ns) {
- return @"$name=$ANSI_COLOR_GREEN'$val'$ANSI_COLOR_END";
+ if (hide_ns) {
+ return printf(ATTRIBUTE_STRING_ANSI_NO_NS_FORMAT, true);
} else {
- return @"$ANSI_COLOR_GRAY{$ns_uri}:$ANSI_COLOR_END$name=$ANSI_COLOR_GREEN'$val'$ANSI_COLOR_END";
+ return printf(ATTRIBUTE_STRING_ANSI_FORMAT);
}
}
- public string to_xml(NamespaceState? state_) throws XmlError {
+ public string to_xml(NamespaceState? state_ = null) throws XmlError {
NamespaceState state = state_ ?? new NamespaceState();
if (ns_uri == state.current_ns_uri || (ns_uri == XMLNS_URI && name == "xmlns")) {
- return @"$name='$val'";
+ return printf(ATTRIBUTE_XML_NO_NS_FORMAT, true);
} else {
- return "%s:%s='%s'".printf (state.find_name (ns_uri), name, val);
+ return printf(ATTRIBUTE_XML_FORMAT, false, state.find_name((!)ns_uri));
+ }
+ }
+
+ public string to_ansi_xml(NamespaceState? state_ = null) throws XmlError {
+ NamespaceState state = state_ ?? new NamespaceState();
+ if (ns_uri == state.current_ns_uri || (ns_uri == XMLNS_URI && name == "xmlns")) {
+ return printf(ATTRIBUTE_XML_ANSI_NO_NS_FORMAT, true);
+ } else {
+ return printf(ATTRIBUTE_XML_ANSI_FORMAT, false, state.find_name((!)ns_uri));
}
}
}
+
}