XML 宣言を表すクラス。
文書から XML 宣言を取り出すには REXML::Document#xml_decl を使います。
require 'rexml/document' doc = REXML::Document.new(<<EOS) <?xml version="1.0" encoding="UTF-8" standalone="yes" ?> <e /> EOS xml_decl = doc.xml_decl xml_decl.version # => "1.0" xml_decl.encoding # => "UTF-8" xml_decl.standalone # => "yes" xml_decl.writethis # => true
XML 宣言を省略した場合の例。
require 'rexml/document' doc = REXML::Document.new(<<EOS) <e /> EOS xml_decl = doc.xml_decl xml_decl.version # => "1.0" xml_decl.encoding # => "UTF-8" xml_decl.standalone # => nil xml_decl.writethis # => false
XML 宣言が encoding 属性を持たない場合の例
require 'rexml/document' doc = REXML::Document.new(<<EOS) <?xml version="1.0" ?> <e /> EOS xml_decl = doc.xml_decl xml_decl.version # => "1.0" xml_decl.encoding # => "UTF-8" xml_decl.standalone # => nil xml_decl.writethis # => true
default -> REXML::XMLDecl
[permalink][rdoc]XML宣言を含まない文章でデフォルトで使うための XMLDecl オブジェクトを生成して返します。
new(version = REXML::XMLDecl::DEFAULT_VERSION, encoding = nil, standalone = nil)
[permalink][rdoc]新たな XMLDecl オブジェクトを生成して返します。
version 以外は省略可能です。
self == other -> bool
[permalink][rdoc]self と other が同じであるならば真を返します。
「同じ」とは REXML::XMLDecl#version, REXML::XMLDecl#encoding, REXML::XMLDecl#standalone が一致していることを意味します。
clone -> REXML::XMLDecl
[permalink][rdoc]self を複製します。
dowrite -> ()
[permalink][rdoc]出力時(REXML::Document#write) に XML 宣言を省略しないよう指示します。
[SEE_ALSO] REXML::XMLDecl#nowrite, REXML::XMLDecl#writethis
encoding -> String | nil
[permalink][rdoc]設定されているエンコーディングの名前を文字列で返します。
エンコーディングが指定されていない(デフォルトの UTF-8 とみなされます) 場合は nil を返します。
encoding=(enc)
[permalink][rdoc]エンコーディングを enc に設定します。
enc に nil を渡すと XML 宣言では encoding が指定されていない(デフォルトで UTF-8 が使われる) ことになります。
[SEE_ALSO] REXML::XMLDecl#encoding=
node_type -> Symbol
[permalink][rdoc]シンボル :xmldecl を返します。
nowrite -> ()
[permalink][rdoc]出力時(REXML::Document#write) に XML 宣言を省略するよう指示します。
[SEE_ALSO] REXML::XMLDecl#dowrite, REXML::XMLDecl#writethis
standalone -> String | nil
[permalink][rdoc]stand_alone? -> String | nil
スタンドアロン文書であるかどうかを "yes" "no" で返します。
nil(省略)を返す場合もあります。
standalone=(value)
[permalink][rdoc]スタンドアロン文書であるかどうかを "yes" "no" で設定します。
この属性を省略したい場合は nil を指定します。
version -> String
[permalink][rdoc]XML文書のバージョンを文字列で返します。
version=(value)
[permalink][rdoc]XML文書のバージョンを設定します。
writeencoding -> bool
[permalink][rdoc]XML宣言内の encoding の宣言を出力時に省略するならば真を返します。
これが真であっても UTF-8 以外のエンコーディングを指定しているならば encoding は出力されます。
writethis -> bool
[permalink][rdoc]出力時(REXML::Document#write) に XML 宣言を出力する(省略しない) ならば真を返します。
[SEE_ALSO] REXML::XMLDecl#dowrite, REXML::XMLDecl#nowrite
xmldecl(version, encoding, standalone) -> ()
[permalink][rdoc]内容を更新します。
DEFAULT_VERSION -> String
[permalink][rdoc]REXML::XMLDecl.new や REXML::XMLDecl.default での使われるデフォルトのXMLバージョン。