document.write('<link rel="stylesheet" href="http://gist.github.com/stylesheets/gist/embed.css"/>')





document.write('<div id=\"gist-229773\" class=\"gist\">\n  \n  \n    \n            \n\n      <div class=\"gist-file\">\n        <div class=\"gist-data gist-syntax\">\n          \n          \n          \n            <div class=\"gist-highlight\"><pre><div class=\"line\" id=\"LC1\"><span class=\"k\">class<\/span> <span class=\"nc\">StateBuilder<\/span><\/div><div class=\"line\" id=\"LC2\">&nbsp;&nbsp;<span class=\"k\">def<\/span> <span class=\"nf\">initialize<\/span><\/div><div class=\"line\" id=\"LC3\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"vi\">@number_created<\/span><\/div><div class=\"line\" id=\"LC4\">&nbsp;&nbsp;<span class=\"k\">end<\/span><\/div><div class=\"line\" id=\"LC5\">&nbsp;<\/div><div class=\"line\" id=\"LC6\">&nbsp;&nbsp;<span class=\"k\">def<\/span> <span class=\"nf\">create_from<\/span><span class=\"p\">(<\/span><span class=\"n\">pattern_string<\/span><span class=\"p\">)<\/span><\/div><div class=\"line\" id=\"LC7\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"n\">string_reader<\/span> <span class=\"o\">=<\/span> <span class=\"no\">StringReader<\/span><span class=\"o\">.<\/span><span class=\"n\">new<\/span><span class=\"p\">(<\/span><span class=\"n\">pattern_string<\/span><span class=\"p\">)<\/span><\/div><div class=\"line\" id=\"LC8\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"n\">root<\/span> <span class=\"o\">=<\/span> <span class=\"n\">_create_start_state<\/span><\/div><div class=\"line\" id=\"LC9\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"n\">current_state<\/span> <span class=\"o\">=<\/span> <span class=\"n\">root<\/span><\/div><div class=\"line\" id=\"LC10\">&nbsp;<\/div><div class=\"line\" id=\"LC11\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"n\">string_reader<\/span><span class=\"o\">.<\/span><span class=\"n\">read_each<\/span> <span class=\"k\">do<\/span> <span class=\"o\">|<\/span><span class=\"n\">current_character<\/span><span class=\"o\">|<\/span><\/div><div class=\"line\" id=\"LC12\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"n\">current_transition<\/span> <span class=\"o\">=<\/span> <span class=\"n\">create_transition<\/span><span class=\"p\">(<\/span><span class=\"n\">current_character<\/span><span class=\"p\">,<\/span> <span class=\"n\">current_state<\/span><span class=\"p\">)<\/span><\/div><div class=\"line\" id=\"LC13\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"n\">current_state<\/span><span class=\"o\">.<\/span><span class=\"n\">add_transition<\/span><span class=\"p\">(<\/span><span class=\"n\">current_transition<\/span><span class=\"p\">)<\/span><\/div><div class=\"line\" id=\"LC14\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"n\">current_state<\/span> <span class=\"o\">=<\/span> <span class=\"n\">current_transition<\/span><span class=\"o\">.<\/span><span class=\"n\">destination<\/span><\/div><div class=\"line\" id=\"LC15\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"k\">end<\/span><\/div><div class=\"line\" id=\"LC16\">&nbsp;<\/div><div class=\"line\" id=\"LC17\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"n\">final_state<\/span> <span class=\"o\">=<\/span> <span class=\"n\">_create_terminal_state<\/span><\/div><div class=\"line\" id=\"LC18\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"n\">final_transition<\/span> <span class=\"o\">=<\/span> <span class=\"no\">AlwaysTransition<\/span><span class=\"o\">.<\/span><span class=\"n\">new<\/span><span class=\"p\">(<\/span><span class=\"n\">final_state<\/span><span class=\"p\">,<\/span> <span class=\"kp\">nil<\/span><span class=\"p\">)<\/span><\/div><div class=\"line\" id=\"LC19\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"n\">current_state<\/span><span class=\"o\">.<\/span><span class=\"n\">add_transition<\/span><span class=\"p\">(<\/span><span class=\"n\">final_transition<\/span><span class=\"p\">)<\/span><\/div><div class=\"line\" id=\"LC20\">&nbsp;<\/div><div class=\"line\" id=\"LC21\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"k\">return<\/span> <span class=\"n\">root<\/span><\/div><div class=\"line\" id=\"LC22\">&nbsp;&nbsp;<span class=\"k\">end<\/span><\/div><div class=\"line\" id=\"LC23\">&nbsp;<\/div><div class=\"line\" id=\"LC24\">&nbsp;&nbsp;<span class=\"k\">def<\/span> <span class=\"nf\">create_transition<\/span><span class=\"p\">(<\/span><span class=\"n\">match_token<\/span><span class=\"p\">,<\/span> <span class=\"n\">previous_state<\/span><span class=\"p\">)<\/span><\/div><div class=\"line\" id=\"LC25\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"k\">case<\/span> <span class=\"n\">match_token<\/span><\/div><div class=\"line\" id=\"LC26\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"k\">when<\/span> <span class=\"s2\">&quot;.&quot;<\/span> <span class=\"k\">then<\/span> <span class=\"no\">MatchAnyTransition<\/span><span class=\"o\">.<\/span><span class=\"n\">new<\/span><span class=\"p\">(<\/span><span class=\"n\">_create_standard_state<\/span><span class=\"p\">,<\/span> <span class=\"n\">match_token<\/span><span class=\"p\">)<\/span><\/div><div class=\"line\" id=\"LC27\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"k\">when<\/span> <span class=\"s2\">&quot;*&quot;<\/span> <span class=\"k\">then<\/span> <span class=\"no\">MatchAnyTransition<\/span><span class=\"o\">.<\/span><span class=\"n\">new<\/span><span class=\"p\">(<\/span><span class=\"n\">previous_state<\/span><span class=\"p\">,<\/span> <span class=\"n\">match_token<\/span><span class=\"p\">)<\/span><\/div><div class=\"line\" id=\"LC28\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"k\">else<\/span> <span class=\"no\">LiteralTransition<\/span><span class=\"o\">.<\/span><span class=\"n\">new<\/span><span class=\"p\">(<\/span><span class=\"n\">_create_standard_state<\/span><span class=\"p\">,<\/span> <span class=\"n\">match_token<\/span><span class=\"p\">)<\/span><\/div><div class=\"line\" id=\"LC29\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"k\">end<\/span><\/div><div class=\"line\" id=\"LC30\">&nbsp;&nbsp;<span class=\"k\">end<\/span><\/div><div class=\"line\" id=\"LC31\">&nbsp;<\/div><div class=\"line\" id=\"LC32\">&nbsp;&nbsp;<span class=\"k\">def<\/span> <span class=\"nf\">_create_terminal_state<\/span><\/div><div class=\"line\" id=\"LC33\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"vi\">@number_created<\/span> <span class=\"o\">+=<\/span> <span class=\"mi\">1<\/span><\/div><div class=\"line\" id=\"LC34\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"n\">result<\/span> <span class=\"o\">=<\/span> <span class=\"no\">TerminalState<\/span><span class=\"o\">.<\/span><span class=\"n\">new<\/span><span class=\"p\">(<\/span><span class=\"vi\">@number_created<\/span><span class=\"p\">)<\/span><\/div><div class=\"line\" id=\"LC35\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"k\">return<\/span> <span class=\"n\">result<\/span><\/div><div class=\"line\" id=\"LC36\">&nbsp;&nbsp;<span class=\"k\">end<\/span><\/div><div class=\"line\" id=\"LC37\">&nbsp;<\/div><div class=\"line\" id=\"LC38\">&nbsp;&nbsp;<span class=\"k\">def<\/span> <span class=\"nf\">_create_start_state<\/span><\/div><div class=\"line\" id=\"LC39\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"vi\">@number_created<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">0<\/span><\/div><div class=\"line\" id=\"LC40\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"n\">result<\/span> <span class=\"o\">=<\/span> <span class=\"no\">StartState<\/span><span class=\"o\">.<\/span><span class=\"n\">new<\/span><span class=\"p\">(<\/span><span class=\"vi\">@number_created<\/span><span class=\"p\">)<\/span><\/div><div class=\"line\" id=\"LC41\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"k\">return<\/span> <span class=\"n\">result<\/span><\/div><div class=\"line\" id=\"LC42\">&nbsp;&nbsp;<span class=\"k\">end<\/span><\/div><div class=\"line\" id=\"LC43\">&nbsp;<\/div><div class=\"line\" id=\"LC44\">&nbsp;&nbsp;<span class=\"k\">def<\/span> <span class=\"nf\">_create_standard_state<\/span><\/div><div class=\"line\" id=\"LC45\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"vi\">@number_created<\/span> <span class=\"o\">+=<\/span> <span class=\"mi\">1<\/span><\/div><div class=\"line\" id=\"LC46\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"n\">result<\/span> <span class=\"o\">=<\/span> <span class=\"no\">StandardState<\/span><span class=\"o\">.<\/span><span class=\"n\">new<\/span><span class=\"p\">(<\/span><span class=\"vi\">@number_created<\/span><span class=\"p\">)<\/span><\/div><div class=\"line\" id=\"LC47\">&nbsp;&nbsp;&nbsp;&nbsp;<span class=\"k\">return<\/span> <span class=\"n\">result<\/span><\/div><div class=\"line\" id=\"LC48\">&nbsp;&nbsp;<span class=\"k\">end<\/span><\/div><div class=\"line\" id=\"LC49\"><span class=\"k\">end<\/span><\/div><\/pre><\/div>\n          \n        <\/div>\n\n        <div class=\"gist-meta\">\n          <a href=\"http://gist.github.com/raw/229773/a35c1f7d1904f1a0bb3eaf179c9ac2ccbed65fff/gistfile1.rb\" style=\"float:right;\">view raw<\/a>\n          <a href=\"http://gist.github.com/229773#file_gistfile1.rb\" style=\"float:right;margin-right:10px;color:#666\">gistfile1.rb<\/a>\n          <a href=\"http://gist.github.com/229773\">This Gist<\/a> brought to you by <a href=\"http://github.com\">GitHub<\/a>.\n        <\/div>\n      <\/div>\n    \n  \n<\/div>\n')
