Sha256: ee8b5c899900c0da91bf5c3e809a90b838a15500d685cc1512a37a4b3f4b4707
Contents?: true
Size: 1.5 KB
Versions: 255
Compression:
Stored size: 1.5 KB
Contents
#include <nokogiri.h> VALUE cNokogiriXmlComment; static ID document_id ; /* * call-seq: * new(document_or_node, content) * * Create a new Comment element on the +document+ with +content+. * Alternatively, if a +node+ is passed, the +node+'s document is used. */ static VALUE new (int argc, VALUE *argv, VALUE klass) { xmlDocPtr xml_doc; xmlNodePtr node; VALUE document; VALUE content; VALUE rest; VALUE rb_node; rb_scan_args(argc, argv, "2*", &document, &content, &rest); if (rb_obj_is_kind_of(document, cNokogiriXmlNode)) { document = rb_funcall(document, document_id, 0); } else if (!rb_obj_is_kind_of(document, cNokogiriXmlDocument) && !rb_obj_is_kind_of(document, cNokogiriXmlDocumentFragment)) { rb_raise(rb_eArgError, "first argument must be a XML::Document or XML::Node"); } Data_Get_Struct(document, xmlDoc, xml_doc); node = xmlNewDocComment( xml_doc, (const xmlChar *)StringValueCStr(content) ); rb_node = noko_xml_node_wrap(klass, node); rb_obj_call_init(rb_node, argc, argv); noko_xml_document_pin_node(node); if (rb_block_given_p()) { rb_yield(rb_node); } return rb_node; } void noko_init_xml_comment() { assert(cNokogiriXmlCharacterData); /* * Comment represents a comment node in an xml document. */ cNokogiriXmlComment = rb_define_class_under(mNokogiriXml, "Comment", cNokogiriXmlCharacterData); rb_define_singleton_method(cNokogiriXmlComment, "new", new, -1); document_id = rb_intern("document"); }
Version data entries
255 entries across 249 versions & 6 rubygems