#
# Copyright (c) 2006-2021 Hal Brodigan (postmodern.mod3 at gmail.com)
#
# This file is part of ronin-support.
#
# ronin-support is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published
# by the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# ronin-support is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with ronin-support. If not, see
one two
" # # @see https://rubydoc.info/stdlib/cgi/1.9.2/CGI.unescapeHTML # # @since 0.2.0 # # @api public # def html_unescape CGI.unescapeHTML(self) end # # Formats the chars in the String for HTML. # # @param [Hash] options # Additional options for {#format_chars}. # # @return [String] # The formatted HTML String. # # @example # "abc".format_html # # => "abc" # # @see Integer#format_html # # @since 0.2.0 # # @api public # def format_html(options={}) # String#ord was not backported to Ruby 1.8.7 formatter = if RUBY_VERSION < '1.9.' then lambda { |c| c[0].format_html } else lambda { |c| c.ord.format_html } end format_chars(options,&formatter) end # # Escapes a String for JavaScript. # # @param [Hash] options # Additional options for {#format_chars}. # # @return [String] # The JavaScript escaped String. # # @example # "hello\nworld\n".js_escape # # => "hello\\nworld\\n" # # @see Integer#js_escape # # @since 0.2.0 # # @api public # def js_escape(options={}) # String#ord was not backported to Rub 1.8.7 formatter = if RUBY_VERSION < '1.9.' then lambda { |c| c[0].js_escape } else lambda { |c| c.ord.js_escape } end format_chars(options,&formatter) end # # Unescapes a JavaScript escaped String. # # @return [String] # The unescaped JavaScript String. # # @example # "\\u0068\\u0065\\u006C\\u006C\\u006F world".js_unescape # # => "hello world" # # @since 0.2.0 # # @api public # def js_unescape unescaped = '' scan(/[\\%]u[0-9a-fA-F]{1,4}|[\\%][0-9a-fA-F]{1,2}|\\[btnfr"\\]|./) do |c| unescaped << JS_BACKSLASHED_CHARS.fetch(c) do if (c.start_with?("\\u") || c.start_with?("%u")) c[2..-1].to_i(16) elsif (c.start_with?("\\") || c.start_with?("%")) c[1..-1].to_i(16) else c end end end return unescaped end # # Escapes a String for JavaScript. # # @param [Hash] options # Additional options for {#format_chars}. # # @return [String] # The JavaScript escaped String. # # @example # "hello".js_escape # # => "\\u0068\\u0065\\u006C\\u006C\\u006F" # # @see Integer#js_escape # # @since 0.2.0 # # @api public # def format_js(options={}) # String#ord was not backported to Rub 1.8.7 formatter = if RUBY_VERSION < '1.9.' then lambda { |c| c[0].format_js } else lambda { |c| c.ord.format_js } end format_chars(options,&formatter) end end