Last active
          April 7, 2022 14:14 
        
      - 
      
 - 
        
Save albertodebortoli/9310424 to your computer and use it in GitHub Desktop.  
    Generate Markdown TOC
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | #!/usr/bin/env ruby | |
| File.open("your_file.md", 'r') do |f| | |
| f.each_line do |line| | |
| forbidden_words = ['Table of contents', 'define', 'pragma'] | |
| next if !line.start_with?("#") || forbidden_words.any? { |w| line =~ /#{w}/ } | |
| title = line.gsub("#", "").strip | |
| href = title.gsub(" ", "-").downcase | |
| puts " " * (line.count("#")-1) + "* [#{title}](\##{href})" | |
| end | |
| end | 
it was also capturing lines commented in code snippets, fix:
#!/usr/bin/env ruby
File.open("finaldocuments/README.md", 'r') do |f|
  inside_code_snippet = false
  f.each_line do |line|
    forbidden_words = ['Table of contents', 'define', 'pragma']
    inside_code_snippet = !inside_code_snippet if line.start_with?('```')
    next if !line.start_with?("#") || forbidden_words.any? { |w| line =~ /#{w}/ } || inside_code_snippet
    title = line.gsub("#", "").strip
    href = title.gsub(" ", "-").downcase
    puts "  " * (line.count("#")-1) + "* [#{title}](\##{href})"
  end
endHas trouble with # inside codeblocks. Mistakes them for a heading.
# This is a heading
I'm a paragraph, dude!
## This is a heading one level below
I'm a hpargarap spelled backwards!
\```
echo "Some code"
# This must not a be heading
echo "s'more code"
\```
The text # This must not be a heading is mistaken for a heading.
Thanks, very nice. Here is a version that takes the file name as an argument:
#!/usr/bin/env ruby
fileName = ARGV[0]
fileName = "README.md" if !fileName
File.open(fileName, 'r') do |f|
  inside_code_snippet = false
  f.each_line do |line|
    forbidden_words = ['Table of contents', 'define', 'pragma']
    inside_code_snippet = !inside_code_snippet if line.start_with?('```')
    next if !line.start_with?("#") || forbidden_words.any? { |w| line =~ /#{w}/ } || inside_code_snippet
    title = line.gsub("#", "").strip
    href = title.gsub(" ", "-").downcase
    puts "  " * (line.count("#")-1) + "* [#{title}](\##{href})"
  end
endI updated and included your script in this repo.
https://github.com/shitana/md_TOC_generator
(I also put the link to your script and profile)
The script is not stripping invalid characters used as Headers. For example,
#### The field `b` means ("bug")
    
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
            
Awesome - thanks!!