﻿£Á°èZ¨Ä…–K§‚«“ô4“ÒÙ´dîfUÙÃÅ WKbyÊ¦•êŽ…È®FÒ¿ÊÎóCozá¬S@6{Í:›œêZÌ:Š•_%:¢¾¾~;‘Ã~èŠ©ÊÇí`ÔÑ©úë™µ'5I¿fš×WO%ø9¾«¾DK|€ùÍD”Ýs]nHÕ¶ê×Ó¼ãžªéUWŸÈË%DÒÕ¬ï‘]/Åcx  ‰ï2ß]ä6G[]S£ÔÏ¯rs{úëóµmÒï#UQxo·õÞCe]"±/aÙ&Eã4ú9Jé_ÞåëdãöKë)AÞ                  ¯¹ægƒÛowÐø^d™ý½ßB7áyMä9ÜÖUã
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
<html>
#!/usr/bin/env ruby
# Finds the latest Passenger crash log directory and prints its path.
# This tool is meant to make it easy to analyze local Passenger crash
# logs during debugging sessions. Instead of searching for the crash
# log directory path in the output and then copy-pasting that to the
# terminal, one can simply invoke one shell command:
#
#   less $(./dev/show-latest-crashlog-dir)/backtrace.log
#
# This will open the latest crash log's backtrace.log in 'less'.

def parse_path(path)
  File.basename(path).split('.')[1].to_i
end

def main
  dirs = Dir["/var/tmp/passenger-crash-log.*.*"].sort do |a, b|
    parse_path(a) <=> parse_path(b)
  end
  if dirs.empty?
    abort "No /var/tmp/passenger-crash-log.* directories found."
  else
    puts dirs.last
  end
end

main
