Represents an XML Instruction; IE, <? … ?> TODO: Add parent arg (3rd arg) to constructor
target is the “name” of the Instruction; IE, the “tag” in <?tag …?> content is everything else.
target is the “name” of the Instruction; IE, the “tag” in <?tag …?> content is everything else.
Constructs a new Instruction @param target can be one of a number of things.  If String, then the target of this instruction is set to this.  If an Instruction, then the Instruction is shallowly cloned (target and content are copied). @param content Must be either a String, or a Parent.  Can only be a Parent if the target argument is a Source.  Otherwise, this String is set as the content of this instruction.
 
               # File rexml/instruction.rb, line 25
def initialize(target, content=nil)
  case target
  when String
    super()
    @target = target
    @content = content
  when Instruction
    super(content)
    @target = target.target
    @content = target.content
  else
    message =
      "processing instruction target must be String or REXML::Instruction: "
    message << "<#{target.inspect}>"
    raise ArgumentError, message
  end
  @content.strip! if @content
end
             
            @return true if other is an Instruction, and the content and target of the other matches the target and content of this object.
 
               # File rexml/instruction.rb, line 65
def ==( other )
  other.kind_of? Instruction and
  other.target == @target and
  other.content == @content
end
             
             
               # File rexml/instruction.rb, line 44
def clone
  Instruction.new self
end
             
             
               # File rexml/instruction.rb, line 75
def inspect
  "<?p-i #{target} ...?>"
end
             
             
               # File rexml/instruction.rb, line 71
def node_type
  :processing_instruction
end
             
            See the rexml/formatters package
 
               # File rexml/instruction.rb, line 51
def write writer, indent=-1, transitive=false, ie_hack=false
  Kernel.warn( "#{self.class.name}.write is deprecated", uplevel: 1)
  indent(writer, indent)
  writer << START
  writer << @target
  if @content
    writer << ' '
    writer << @content
  end
  writer << STOP
end