iniparse 1.1.6 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/Gemfile +1 -1
- data/README.rdoc +16 -0
- data/Rakefile +1 -1
- data/iniparse.gemspec +8 -21
- data/lib/iniparse.rb +1 -1
- data/lib/iniparse/line_collection.rb +4 -2
- data/lib/iniparse/lines.rb +24 -1
- data/lib/iniparse/parser.rb +4 -3
- metadata +16 -47
- data/spec/document_spec.rb +0 -88
- data/spec/fixture_spec.rb +0 -166
- data/spec/fixtures/openttd.ini +0 -397
- data/spec/fixtures/race07.ini +0 -133
- data/spec/fixtures/smb.ini +0 -102
- data/spec/generator/method_missing_spec.rb +0 -104
- data/spec/generator/with_section_blocks_spec.rb +0 -322
- data/spec/generator/without_section_blocks_spec.rb +0 -136
- data/spec/iniparse_spec.rb +0 -21
- data/spec/line_collection_spec.rb +0 -214
- data/spec/lines_spec.rb +0 -407
- data/spec/parser/document_parsing_spec.rb +0 -82
- data/spec/parser/line_parsing_spec.rb +0 -382
- data/spec/spec_fixtures.rb +0 -62
- data/spec/spec_helper.rb +0 -168
- data/spec/spec_helper_spec.rb +0 -201
    
        data/spec/fixtures/smb.ini
    DELETED
    
    | @@ -1,102 +0,0 @@ | |
| 1 | 
            -
            ; Configuration file for the Samba software suite.
         | 
| 2 | 
            -
            ; ============================================================================
         | 
| 3 | 
            -
            ;
         | 
| 4 | 
            -
            ; For the format of this file and comprehensive descriptions of all the
         | 
| 5 | 
            -
            ; configuration option, please refer to the man page for smb.conf(5).
         | 
| 6 | 
            -
            ;
         | 
| 7 | 
            -
            ; The following configuration should suit most systems for basic usage and
         | 
| 8 | 
            -
            ; initial testing. It gives all clients access to their home directories and
         | 
| 9 | 
            -
            ; allows access to all printers specified in /etc/printcap.
         | 
| 10 | 
            -
             | 
| 11 | 
            -
            ; BEGIN required configuration
         | 
| 12 | 
            -
             | 
| 13 | 
            -
            ; Parameters inside the required configuration block should not be altered.
         | 
| 14 | 
            -
            ; They may be changed at any time by upgrades or other automated processes.
         | 
| 15 | 
            -
            ;
         | 
| 16 | 
            -
            ; Site-specific customizations will only be preserved if they are done
         | 
| 17 | 
            -
            ; outside this block. If you choose to make customizations, it is your
         | 
| 18 | 
            -
            ; own responsibility to verify that they work correctly with the supported
         | 
| 19 | 
            -
            ; configuration tools.
         | 
| 20 | 
            -
             | 
| 21 | 
            -
            [global]
         | 
| 22 | 
            -
                debug pid = yes
         | 
| 23 | 
            -
                log level = 1
         | 
| 24 | 
            -
                server string = Mac OS X
         | 
| 25 | 
            -
             | 
| 26 | 
            -
                printcap name = cups
         | 
| 27 | 
            -
                printing = cups
         | 
| 28 | 
            -
             | 
| 29 | 
            -
                encrypt passwords = yes
         | 
| 30 | 
            -
                use spnego = yes
         | 
| 31 | 
            -
             | 
| 32 | 
            -
                passdb backend = odsam
         | 
| 33 | 
            -
             | 
| 34 | 
            -
                idmap domains = default
         | 
| 35 | 
            -
                idmap config default: default = yes
         | 
| 36 | 
            -
                idmap config default: backend = odsam
         | 
| 37 | 
            -
                idmap alloc backend = odsam
         | 
| 38 | 
            -
                idmap negative cache time = 5
         | 
| 39 | 
            -
             | 
| 40 | 
            -
                map to guest = Bad User
         | 
| 41 | 
            -
                guest account = nobody
         | 
| 42 | 
            -
             | 
| 43 | 
            -
                unix charset = UTF-8-MAC
         | 
| 44 | 
            -
                display charset = UTF-8-MAC
         | 
| 45 | 
            -
                dos charset = 437
         | 
| 46 | 
            -
             | 
| 47 | 
            -
                vfs objects = darwinacl,darwin_streams
         | 
| 48 | 
            -
             | 
| 49 | 
            -
                ; Don't become a master browser unless absolutely necessary.
         | 
| 50 | 
            -
                os level = 2
         | 
| 51 | 
            -
                domain master = no
         | 
| 52 | 
            -
             | 
| 53 | 
            -
                ; For performance reasons, set the transmit buffer size
         | 
| 54 | 
            -
                ; to the maximum and enable sendfile support.
         | 
| 55 | 
            -
                max xmit = 131072
         | 
| 56 | 
            -
                use sendfile = yes
         | 
| 57 | 
            -
             | 
| 58 | 
            -
                ; The darwin_streams module gives us named streams support.
         | 
| 59 | 
            -
                stream support = yes
         | 
| 60 | 
            -
                ea support = yes
         | 
| 61 | 
            -
             | 
| 62 | 
            -
                ; Enable locking coherency with AFP.
         | 
| 63 | 
            -
                darwin_streams:brlm = yes
         | 
| 64 | 
            -
             | 
| 65 | 
            -
                ; Core files are invariably disabled system-wide, but attempting to
         | 
| 66 | 
            -
                ; dump core will trigger a crash report, so we still want to try.
         | 
| 67 | 
            -
                enable core files = yes
         | 
| 68 | 
            -
             | 
| 69 | 
            -
                ; Configure usershares for use by the synchronize-shares tool.
         | 
| 70 | 
            -
                usershare max shares = 1000
         | 
| 71 | 
            -
                usershare path = /var/samba/shares
         | 
| 72 | 
            -
                usershare owner only = no
         | 
| 73 | 
            -
                usershare allow guests = yes
         | 
| 74 | 
            -
                usershare allow full config = yes
         | 
| 75 | 
            -
             | 
| 76 | 
            -
                ; Filter inaccessible shares from the browse list.
         | 
| 77 | 
            -
                com.apple:filter shares by access = yes
         | 
| 78 | 
            -
             | 
| 79 | 
            -
                ; Check in with PAM to enforce SACL access policy.
         | 
| 80 | 
            -
                obey pam restrictions = yes
         | 
| 81 | 
            -
             | 
| 82 | 
            -
                ; Don't be trying to enforce ACLs in userspace.
         | 
| 83 | 
            -
                acl check permissions = no
         | 
| 84 | 
            -
             | 
| 85 | 
            -
                ; Make sure that we resolve unqualified names as NetBIOS before DNS.
         | 
| 86 | 
            -
                name resolve order = lmhosts wins bcast host
         | 
| 87 | 
            -
             | 
| 88 | 
            -
                ; Pull in system-wide preference settings. These are managed by
         | 
| 89 | 
            -
                ; synchronize-preferences tool.
         | 
| 90 | 
            -
                include = /var/db/smb.conf
         | 
| 91 | 
            -
             | 
| 92 | 
            -
            [printers]
         | 
| 93 | 
            -
                comment = All Printers
         | 
| 94 | 
            -
                path = /tmp
         | 
| 95 | 
            -
                printable = yes
         | 
| 96 | 
            -
                guest ok = no
         | 
| 97 | 
            -
                create mode = 0700
         | 
| 98 | 
            -
                writeable = no
         | 
| 99 | 
            -
                browseable = no
         | 
| 100 | 
            -
             | 
| 101 | 
            -
            ; Site-specific parameters can be added below this comment.
         | 
| 102 | 
            -
            ; END required configuration.
         | 
| @@ -1,104 +0,0 @@ | |
| 1 | 
            -
            require 'spec_helper'
         | 
| 2 | 
            -
             | 
| 3 | 
            -
            # Tests use of the Generator when used like so:
         | 
| 4 | 
            -
            #
         | 
| 5 | 
            -
            #   IniParse::Generator.gen do |doc|
         | 
| 6 | 
            -
            #     doc.comment 'My very own comment'
         | 
| 7 | 
            -
            #     doc.my_section do |section|
         | 
| 8 | 
            -
            #       section.my_option = 'my value'
         | 
| 9 | 
            -
            #     end
         | 
| 10 | 
            -
            #   end
         | 
| 11 | 
            -
            #
         | 
| 12 | 
            -
             | 
| 13 | 
            -
            describe 'When generating a document using Generator with section blocks using method_missing,' do
         | 
| 14 | 
            -
             | 
| 15 | 
            -
              # --
         | 
| 16 | 
            -
              # ==========================================================================
         | 
| 17 | 
            -
              #   SECTION LINES
         | 
| 18 | 
            -
              # ==========================================================================
         | 
| 19 | 
            -
              # ++
         | 
| 20 | 
            -
             | 
| 21 | 
            -
              describe 'adding a section' do
         | 
| 22 | 
            -
                it 'should yield an object with generator methods' do
         | 
| 23 | 
            -
                  IniParse::Generator.gen do |doc|
         | 
| 24 | 
            -
                    doc.a_section do |section|
         | 
| 25 | 
            -
                      %w( option comment blank ).each do |meth|
         | 
| 26 | 
            -
                        section.should respond_to(meth)
         | 
| 27 | 
            -
                      end
         | 
| 28 | 
            -
                    end
         | 
| 29 | 
            -
                  end
         | 
| 30 | 
            -
                end
         | 
| 31 | 
            -
             | 
| 32 | 
            -
                it 'should add a Section to the document' do
         | 
| 33 | 
            -
                  IniParse::Generator.gen do |doc|
         | 
| 34 | 
            -
                    doc.a_section { |section| }
         | 
| 35 | 
            -
                  end.should have_section("a_section")
         | 
| 36 | 
            -
                end
         | 
| 37 | 
            -
             | 
| 38 | 
            -
                it 'should change the Generator context to the section during the section block' do
         | 
| 39 | 
            -
                  IniParse::Generator.gen do |doc|
         | 
| 40 | 
            -
                    doc.a_section do |section|
         | 
| 41 | 
            -
                      section.context.should be_kind_of(IniParse::Lines::Section)
         | 
| 42 | 
            -
                      section.context.key.should == "a_section"
         | 
| 43 | 
            -
                    end
         | 
| 44 | 
            -
                  end
         | 
| 45 | 
            -
                end
         | 
| 46 | 
            -
             | 
| 47 | 
            -
                it 'should reset the Generator context to the document after the section block' do
         | 
| 48 | 
            -
                  IniParse::Generator.gen do |doc|
         | 
| 49 | 
            -
                    doc.a_section { |section| }
         | 
| 50 | 
            -
                    doc.context.should be_kind_of(IniParse::Document)
         | 
| 51 | 
            -
                  end
         | 
| 52 | 
            -
                end
         | 
| 53 | 
            -
             | 
| 54 | 
            -
                it 'should append a blank line to the document, after the section' do
         | 
| 55 | 
            -
                  IniParse::Generator.gen do |doc|
         | 
| 56 | 
            -
                    doc.a_section { |section| }
         | 
| 57 | 
            -
                  end.lines.to_a.last.should be_kind_of(IniParse::Lines::Blank)
         | 
| 58 | 
            -
                end
         | 
| 59 | 
            -
             | 
| 60 | 
            -
                it 'should raise a LineNotAllowed if you attempt to nest a section' do
         | 
| 61 | 
            -
                  lambda do
         | 
| 62 | 
            -
                    IniParse::Generator.gen do |doc|
         | 
| 63 | 
            -
                      doc.a_section do |section_one|
         | 
| 64 | 
            -
                        section_one.another_section { |section_two| }
         | 
| 65 | 
            -
                      end
         | 
| 66 | 
            -
                    end
         | 
| 67 | 
            -
                  end.should raise_error(IniParse::LineNotAllowed)
         | 
| 68 | 
            -
                end
         | 
| 69 | 
            -
              end
         | 
| 70 | 
            -
             | 
| 71 | 
            -
              # --
         | 
| 72 | 
            -
              # ==========================================================================
         | 
| 73 | 
            -
              #   OPTION LINES
         | 
| 74 | 
            -
              # ==========================================================================
         | 
| 75 | 
            -
              # ++
         | 
| 76 | 
            -
             | 
| 77 | 
            -
              describe 'adding a option' do
         | 
| 78 | 
            -
                describe 'when the context is a Document' do
         | 
| 79 | 
            -
                  it "should raise a NoSectionError" do
         | 
| 80 | 
            -
                    lambda do
         | 
| 81 | 
            -
                      IniParse::Generator.gen { |doc| doc.my_option = "a value" }
         | 
| 82 | 
            -
                    end.should raise_error(IniParse::NoSectionError)
         | 
| 83 | 
            -
                  end
         | 
| 84 | 
            -
                end
         | 
| 85 | 
            -
             | 
| 86 | 
            -
                describe 'when the context is a Section' do
         | 
| 87 | 
            -
                  it 'should add the option to the section' do
         | 
| 88 | 
            -
                    document = IniParse::Generator.gen do |doc|
         | 
| 89 | 
            -
                      doc.a_section do |section|
         | 
| 90 | 
            -
                        section.my_option = "a value"
         | 
| 91 | 
            -
                      end
         | 
| 92 | 
            -
                    end
         | 
| 93 | 
            -
             | 
| 94 | 
            -
                    section = document["a_section"]
         | 
| 95 | 
            -
                    section.should have_option("my_option")
         | 
| 96 | 
            -
                    section["my_option"].should == "a value"
         | 
| 97 | 
            -
                  end
         | 
| 98 | 
            -
                end
         | 
| 99 | 
            -
              end
         | 
| 100 | 
            -
             | 
| 101 | 
            -
              # Comments and blanks are added in the same way as in the
         | 
| 102 | 
            -
              # 'with_section_block_spec.rb' specification.
         | 
| 103 | 
            -
             | 
| 104 | 
            -
            end
         | 
| @@ -1,322 +0,0 @@ | |
| 1 | 
            -
            require 'spec_helper'
         | 
| 2 | 
            -
             | 
| 3 | 
            -
            # Tests use of the Generator when used like so:
         | 
| 4 | 
            -
            #
         | 
| 5 | 
            -
            #   IniParse::Generator.gen do |doc|
         | 
| 6 | 
            -
            #     doc.comment('My very own comment')
         | 
| 7 | 
            -
            #     doc.section('my_section') do |section|
         | 
| 8 | 
            -
            #       section.option('my_option', 'my value')
         | 
| 9 | 
            -
            #     end
         | 
| 10 | 
            -
            #   end
         | 
| 11 | 
            -
            #
         | 
| 12 | 
            -
             | 
| 13 | 
            -
            describe 'When generating a document using Generator with section blocks,' do
         | 
| 14 | 
            -
             | 
| 15 | 
            -
              it 'should be able to compile an empty document' do
         | 
| 16 | 
            -
                lambda { IniParse::Generator.gen { |doc| } }.should_not raise_error
         | 
| 17 | 
            -
              end
         | 
| 18 | 
            -
             | 
| 19 | 
            -
              it 'should raise LocalJumpError if no block is given' do
         | 
| 20 | 
            -
                lambda { IniParse::Generator.gen }.should raise_error(LocalJumpError)
         | 
| 21 | 
            -
              end
         | 
| 22 | 
            -
             | 
| 23 | 
            -
              it "should yield an object with generator methods" do
         | 
| 24 | 
            -
                IniParse::Generator.gen do |doc|
         | 
| 25 | 
            -
                  %w( section option comment blank ).each do |meth|
         | 
| 26 | 
            -
                    doc.should respond_to(meth)
         | 
| 27 | 
            -
                  end
         | 
| 28 | 
            -
                end
         | 
| 29 | 
            -
              end
         | 
| 30 | 
            -
             | 
| 31 | 
            -
              # --
         | 
| 32 | 
            -
              # ==========================================================================
         | 
| 33 | 
            -
              #   SECTION LINES
         | 
| 34 | 
            -
              # ==========================================================================
         | 
| 35 | 
            -
              # ++
         | 
| 36 | 
            -
             | 
| 37 | 
            -
              describe 'adding a section' do
         | 
| 38 | 
            -
                it 'should yield an object with generator methods' do
         | 
| 39 | 
            -
                  IniParse::Generator.gen do |doc|
         | 
| 40 | 
            -
                    doc.section("a section") do |section|
         | 
| 41 | 
            -
                      %w( option comment blank ).each do |meth|
         | 
| 42 | 
            -
                        section.should respond_to(meth)
         | 
| 43 | 
            -
                      end
         | 
| 44 | 
            -
                    end
         | 
| 45 | 
            -
                  end
         | 
| 46 | 
            -
                end
         | 
| 47 | 
            -
             | 
| 48 | 
            -
                it 'should add a Section to the document' do
         | 
| 49 | 
            -
                  IniParse::Generator.gen do |doc|
         | 
| 50 | 
            -
                    doc.section("a section") { |section| }
         | 
| 51 | 
            -
                  end.should have_section("a section")
         | 
| 52 | 
            -
                end
         | 
| 53 | 
            -
             | 
| 54 | 
            -
                it 'should change the Generator context to the section during the section block' do
         | 
| 55 | 
            -
                  IniParse::Generator.gen do |doc|
         | 
| 56 | 
            -
                    doc.section("a section") do |section|
         | 
| 57 | 
            -
                      section.context.should be_kind_of(IniParse::Lines::Section)
         | 
| 58 | 
            -
                      section.context.key.should == "a section"
         | 
| 59 | 
            -
                    end
         | 
| 60 | 
            -
                  end
         | 
| 61 | 
            -
                end
         | 
| 62 | 
            -
             | 
| 63 | 
            -
                it 'should reset the Generator context to the document after the section block' do
         | 
| 64 | 
            -
                  IniParse::Generator.gen do |doc|
         | 
| 65 | 
            -
                    doc.section("a section") { |section| }
         | 
| 66 | 
            -
                    doc.context.should be_kind_of(IniParse::Document)
         | 
| 67 | 
            -
                  end
         | 
| 68 | 
            -
                end
         | 
| 69 | 
            -
             | 
| 70 | 
            -
                it "should use the parent document's options as a base" do
         | 
| 71 | 
            -
                  document = IniParse::Generator.gen(:indent => '    ') do |doc|
         | 
| 72 | 
            -
                    doc.section("a section") { |section| }
         | 
| 73 | 
            -
                  end
         | 
| 74 | 
            -
             | 
| 75 | 
            -
                  document["a section"].to_ini.should match(/\A    /)
         | 
| 76 | 
            -
                end
         | 
| 77 | 
            -
             | 
| 78 | 
            -
                it 'should pass extra options to the Section instance' do
         | 
| 79 | 
            -
                  document = IniParse::Generator.gen do |doc|
         | 
| 80 | 
            -
                    doc.section("a section", :indent => '    ') { |section| }
         | 
| 81 | 
            -
                  end
         | 
| 82 | 
            -
             | 
| 83 | 
            -
                  document["a section"].to_ini.should match(/\A    /)
         | 
| 84 | 
            -
                end
         | 
| 85 | 
            -
             | 
| 86 | 
            -
                it 'should append a blank line to the document, after the section' do
         | 
| 87 | 
            -
                  IniParse::Generator.gen do |doc|
         | 
| 88 | 
            -
                    doc.section("a section") { |section| }
         | 
| 89 | 
            -
                  end.lines.to_a.last.should be_kind_of(IniParse::Lines::Blank)
         | 
| 90 | 
            -
                end
         | 
| 91 | 
            -
             | 
| 92 | 
            -
                it 'should raise a LineNotAllowed if you attempt to nest a section' do
         | 
| 93 | 
            -
                  lambda do
         | 
| 94 | 
            -
                    IniParse::Generator.gen do |doc|
         | 
| 95 | 
            -
                      doc.section("a section") do |section_one|
         | 
| 96 | 
            -
                        section_one.section("another_section") { |section_two| }
         | 
| 97 | 
            -
                      end
         | 
| 98 | 
            -
                    end
         | 
| 99 | 
            -
                  end.should raise_error(IniParse::LineNotAllowed)
         | 
| 100 | 
            -
                end
         | 
| 101 | 
            -
              end
         | 
| 102 | 
            -
             | 
| 103 | 
            -
              # --
         | 
| 104 | 
            -
              # ==========================================================================
         | 
| 105 | 
            -
              #   OPTION LINES
         | 
| 106 | 
            -
              # ==========================================================================
         | 
| 107 | 
            -
              # ++
         | 
| 108 | 
            -
             | 
| 109 | 
            -
              describe 'adding a option' do
         | 
| 110 | 
            -
             | 
| 111 | 
            -
                describe 'when the context is a Document' do
         | 
| 112 | 
            -
                  it "should raise a NoSectionError" do
         | 
| 113 | 
            -
                    lambda do
         | 
| 114 | 
            -
                      IniParse::Generator.gen do |doc|
         | 
| 115 | 
            -
                        doc.option("my option", "a value")
         | 
| 116 | 
            -
                      end
         | 
| 117 | 
            -
                    end.should raise_error(IniParse::NoSectionError)
         | 
| 118 | 
            -
                  end
         | 
| 119 | 
            -
                end
         | 
| 120 | 
            -
             | 
| 121 | 
            -
                describe 'when the context is a Section' do
         | 
| 122 | 
            -
                  it 'should add the option to the section' do
         | 
| 123 | 
            -
                    document = IniParse::Generator.gen do |doc|
         | 
| 124 | 
            -
                      doc.section("a section") do |section|
         | 
| 125 | 
            -
                        section.option("my option", "a value")
         | 
| 126 | 
            -
                      end
         | 
| 127 | 
            -
                    end
         | 
| 128 | 
            -
             | 
| 129 | 
            -
                    section = document["a section"]
         | 
| 130 | 
            -
                    section.should have_option("my option")
         | 
| 131 | 
            -
                    section["my option"].should == "a value"
         | 
| 132 | 
            -
                  end
         | 
| 133 | 
            -
             | 
| 134 | 
            -
                  it 'should pass extra options to the Option instance' do
         | 
| 135 | 
            -
                    document = IniParse::Generator.gen do |doc|
         | 
| 136 | 
            -
                      doc.section("a section") do |section|
         | 
| 137 | 
            -
                        section.option("my option", "a value", :indent => "    ")
         | 
| 138 | 
            -
                      end
         | 
| 139 | 
            -
                    end
         | 
| 140 | 
            -
             | 
| 141 | 
            -
                    document["a section"].option("my option").to_ini.should match(/^    /)
         | 
| 142 | 
            -
                  end
         | 
| 143 | 
            -
             | 
| 144 | 
            -
                  it "should use the parent document's options as a base" do
         | 
| 145 | 
            -
                    document = IniParse::Generator.gen(:indent => "    ") do |doc|
         | 
| 146 | 
            -
                      doc.section("a section") do |section|
         | 
| 147 | 
            -
                        section.option("my option", "a value")
         | 
| 148 | 
            -
                      end
         | 
| 149 | 
            -
                    end
         | 
| 150 | 
            -
             | 
| 151 | 
            -
                    document["a section"].option("my option").to_ini.should match(/^    /)
         | 
| 152 | 
            -
                  end
         | 
| 153 | 
            -
             | 
| 154 | 
            -
                  it "should use the parent section's options as a base" do
         | 
| 155 | 
            -
                    document = IniParse::Generator.gen do |doc|
         | 
| 156 | 
            -
                      doc.section("a section", :indent => "    ") do |section|
         | 
| 157 | 
            -
                        section.option("my option", "a value")
         | 
| 158 | 
            -
                      end
         | 
| 159 | 
            -
                    end
         | 
| 160 | 
            -
             | 
| 161 | 
            -
                    document["a section"].option("my option").to_ini.should match(/^    /)
         | 
| 162 | 
            -
                  end
         | 
| 163 | 
            -
             | 
| 164 | 
            -
                  it "should allow customisation of the parent's options" do
         | 
| 165 | 
            -
                    document = IniParse::Generator.gen do |doc|
         | 
| 166 | 
            -
                      doc.section("a section", :indent => "    ") do |section|
         | 
| 167 | 
            -
                        section.option("my option", "a value", {
         | 
| 168 | 
            -
                          :comment_sep => "#", :comment => 'a comment'
         | 
| 169 | 
            -
                        })
         | 
| 170 | 
            -
                      end
         | 
| 171 | 
            -
                    end
         | 
| 172 | 
            -
             | 
| 173 | 
            -
                    option_ini = document["a section"].option("my option").to_ini
         | 
| 174 | 
            -
                    option_ini.should match(/^    /)
         | 
| 175 | 
            -
                    option_ini.should match(/ # a comment/)
         | 
| 176 | 
            -
                  end
         | 
| 177 | 
            -
             | 
| 178 | 
            -
                  it "should not use the parent section's comment when setting line options" do
         | 
| 179 | 
            -
                    document = IniParse::Generator.gen do |doc|
         | 
| 180 | 
            -
                      doc.section("a section", :comment => "My section") do |section|
         | 
| 181 | 
            -
                        section.option("my option", "a value")
         | 
| 182 | 
            -
                      end
         | 
| 183 | 
            -
                    end
         | 
| 184 | 
            -
             | 
| 185 | 
            -
                    document["a section"].option("my option").to_ini.should_not match(/My section$/)
         | 
| 186 | 
            -
                  end
         | 
| 187 | 
            -
                end
         | 
| 188 | 
            -
              end
         | 
| 189 | 
            -
             | 
| 190 | 
            -
              # --
         | 
| 191 | 
            -
              # ==========================================================================
         | 
| 192 | 
            -
              #   COMMENT LINES
         | 
| 193 | 
            -
              # ==========================================================================
         | 
| 194 | 
            -
              # ++
         | 
| 195 | 
            -
             | 
| 196 | 
            -
              describe 'adding a comment' do
         | 
| 197 | 
            -
                it 'should pass extra options to the Option instance' do
         | 
| 198 | 
            -
                  document = IniParse::Generator.gen do |doc|
         | 
| 199 | 
            -
                    doc.comment("My comment", :indent => '    ')
         | 
| 200 | 
            -
                  end
         | 
| 201 | 
            -
             | 
| 202 | 
            -
                  document.lines.to_a.first.to_ini.should match(/\A    /)
         | 
| 203 | 
            -
                end
         | 
| 204 | 
            -
             | 
| 205 | 
            -
                it 'should ignore any extra :comment option' do
         | 
| 206 | 
            -
                  document = IniParse::Generator.gen do |doc|
         | 
| 207 | 
            -
                    doc.comment("My comment", :comment => 'Ignored')
         | 
| 208 | 
            -
                  end
         | 
| 209 | 
            -
             | 
| 210 | 
            -
                  document.lines.to_a.first.to_ini.should match(/My comment/)
         | 
| 211 | 
            -
                  document.lines.to_a.first.to_ini.should_not match(/Ignored/)
         | 
| 212 | 
            -
                end
         | 
| 213 | 
            -
             | 
| 214 | 
            -
                describe 'when the context is a Document' do
         | 
| 215 | 
            -
                  it 'should add a comment to the document' do
         | 
| 216 | 
            -
                    document = IniParse::Generator.gen do |doc|
         | 
| 217 | 
            -
                      doc.comment("My comment")
         | 
| 218 | 
            -
                    end
         | 
| 219 | 
            -
             | 
| 220 | 
            -
                    comment = document.lines.to_a.first
         | 
| 221 | 
            -
                    comment.should be_kind_of(IniParse::Lines::Comment)
         | 
| 222 | 
            -
                    comment.to_ini.should match(/My comment/)
         | 
| 223 | 
            -
                  end
         | 
| 224 | 
            -
             | 
| 225 | 
            -
                  it 'should use the default line options as a base' do
         | 
| 226 | 
            -
                    document = IniParse::Generator.gen do |doc|
         | 
| 227 | 
            -
                      doc.comment("My comment")
         | 
| 228 | 
            -
                    end
         | 
| 229 | 
            -
             | 
| 230 | 
            -
                    comment_ini = document.lines.to_a.first.to_ini
         | 
| 231 | 
            -
             | 
| 232 | 
            -
                    # Match separator (;) and offset (0).
         | 
| 233 | 
            -
                    comment_ini.should == '; My comment'
         | 
| 234 | 
            -
                  end
         | 
| 235 | 
            -
                end
         | 
| 236 | 
            -
             | 
| 237 | 
            -
                describe 'when the context is a Section' do
         | 
| 238 | 
            -
                  it 'should add a comment to the section' do
         | 
| 239 | 
            -
                    document = IniParse::Generator.gen do |doc|
         | 
| 240 | 
            -
                      doc.section("a section") do |section|
         | 
| 241 | 
            -
                        section.comment("My comment")
         | 
| 242 | 
            -
                      end
         | 
| 243 | 
            -
                    end
         | 
| 244 | 
            -
             | 
| 245 | 
            -
                    comment = document['a section'].lines.to_a.first
         | 
| 246 | 
            -
                    comment.should be_kind_of(IniParse::Lines::Comment)
         | 
| 247 | 
            -
                    comment.to_ini.should match(/My comment/)
         | 
| 248 | 
            -
                  end
         | 
| 249 | 
            -
             | 
| 250 | 
            -
                  it "should use the parent document's line options as a base" do
         | 
| 251 | 
            -
                    document = IniParse::Generator.gen(:comment_offset => 5) do |doc|
         | 
| 252 | 
            -
                      doc.section("a section") do |section|
         | 
| 253 | 
            -
                        section.comment("My comment")
         | 
| 254 | 
            -
                      end
         | 
| 255 | 
            -
                    end
         | 
| 256 | 
            -
             | 
| 257 | 
            -
                    document['a section'].lines.to_a.first.to_ini.should match(/^     ;/)
         | 
| 258 | 
            -
                  end
         | 
| 259 | 
            -
             | 
| 260 | 
            -
                  it "should use the parent section's line options as a base" do
         | 
| 261 | 
            -
                    document = IniParse::Generator.gen do |doc|
         | 
| 262 | 
            -
                      doc.section("a section", :comment_offset => 5) do |section|
         | 
| 263 | 
            -
                        section.comment("My comment")
         | 
| 264 | 
            -
                      end
         | 
| 265 | 
            -
                    end
         | 
| 266 | 
            -
             | 
| 267 | 
            -
                    document['a section'].lines.to_a.first.to_ini.should match(/^     ;/)
         | 
| 268 | 
            -
                  end
         | 
| 269 | 
            -
             | 
| 270 | 
            -
                  it "should allow customisation of the parent's options" do
         | 
| 271 | 
            -
                    document = IniParse::Generator.gen do |doc|
         | 
| 272 | 
            -
                      doc.section("a section", :comment_offset => 5) do |section|
         | 
| 273 | 
            -
                        section.comment("My comment", :comment_sep => "#")
         | 
| 274 | 
            -
                      end
         | 
| 275 | 
            -
                    end
         | 
| 276 | 
            -
             | 
| 277 | 
            -
                    # Match separator (#) and offset (5)
         | 
| 278 | 
            -
                    document['a section'].lines.to_a.first.to_ini.should \
         | 
| 279 | 
            -
                      == '     # My comment'
         | 
| 280 | 
            -
                  end
         | 
| 281 | 
            -
             | 
| 282 | 
            -
                  it "should not use the parent section's comment when setting line options" do
         | 
| 283 | 
            -
                    document = IniParse::Generator.gen do |doc|
         | 
| 284 | 
            -
                      doc.section("a section", :comment => "My section") do |section|
         | 
| 285 | 
            -
                        section.comment("My comment")
         | 
| 286 | 
            -
                      end
         | 
| 287 | 
            -
                    end
         | 
| 288 | 
            -
             | 
| 289 | 
            -
                    comment_ini = document['a section'].lines.to_a.first.to_ini
         | 
| 290 | 
            -
                    comment_ini.should match(/My comment/)
         | 
| 291 | 
            -
                    comment_ini.should_not match(/My section/)
         | 
| 292 | 
            -
                  end
         | 
| 293 | 
            -
                end
         | 
| 294 | 
            -
              end
         | 
| 295 | 
            -
             | 
| 296 | 
            -
              # --
         | 
| 297 | 
            -
              # ==========================================================================
         | 
| 298 | 
            -
              #   BLANK LINES
         | 
| 299 | 
            -
              # ==========================================================================
         | 
| 300 | 
            -
              # ++
         | 
| 301 | 
            -
             | 
| 302 | 
            -
              describe 'adding a blank line' do
         | 
| 303 | 
            -
                it 'should add a blank line to the document when it is the context' do
         | 
| 304 | 
            -
                  document = IniParse::Generator.gen do |doc|
         | 
| 305 | 
            -
                    doc.blank
         | 
| 306 | 
            -
                  end
         | 
| 307 | 
            -
             | 
| 308 | 
            -
                  document.lines.to_a.first.should be_kind_of(IniParse::Lines::Blank)
         | 
| 309 | 
            -
                end
         | 
| 310 | 
            -
             | 
| 311 | 
            -
                it 'should add a blank line to the section when it is the context' do
         | 
| 312 | 
            -
                  document = IniParse::Generator.gen do |doc|
         | 
| 313 | 
            -
                    doc.section("a section") do |section|
         | 
| 314 | 
            -
                      section.blank
         | 
| 315 | 
            -
                    end
         | 
| 316 | 
            -
                  end
         | 
| 317 | 
            -
             | 
| 318 | 
            -
                  document['a section'].lines.to_a.first.should be_kind_of(IniParse::Lines::Blank)
         | 
| 319 | 
            -
                end
         | 
| 320 | 
            -
              end
         | 
| 321 | 
            -
             | 
| 322 | 
            -
            end
         |