Welcome to HBH! If you have tried to register and didn't get a verification email, please using the following link to resend the verification email.
symbol - Ruby Code Bank
symbol
symbolic keyword thought management, including revisioning system, utilizing mysql
you might have to grok the table structure yourself
#!/usr/bin/ruby
require "mysql"
$sql = Mysql::real_connect("localhost","user","password")
$sql.select_db("symbols")
$action = ""
$options = ""
$opts = %w{ add change delete help list revert view }
def query(q)
begin
return $sql.query(q)
rescue Mysql::Error => e
puts "E#{e.errno}: #{e.error}"
end
end
def help(what=:default)
print "Usage: "
case what
when :action
puts "A bit of an uncreative thinker, I suppose. Well, let me clarify."
puts "When I say do help action, I mean do help, then type the name of an aforementioned command."
puts "It'll give you help on that command. You want I should call MENSA now?"
when :add
puts "add entryname [description|file=filename]"
puts "\tAdds entryname into the database, and prompts you for a description, if one is not given."
puts "\tAlso note that you can give the option file=filename to read in a filename"
puts "\tExample: add entryname description adds entryname with the description text as 'description'"
when :change
puts "change entryname [description]"
puts "\tChanges entryname to new description if given, else prompts for a new one."
when :delete
puts "delete [entryname[-rev=1,2,..n] ...entrynamen]"
puts "\tDeletes all entries given; if none are given, prompts for a newline delimited list"
puts "\tIf you only want to delete specific revisions, do for example entry-rev=1"
puts "\t Example: delete entry entry2-rev=1 entry3-rev=3-5 deletes entry, entry2 revision 1, and entry3 revisions 3 and 5"
when :default
puts "symbol ["+$opts.join("|")+"]"
puts "If you need clarification on a specific action, do help action"
when :help
puts "help [action], where action is one of:"
print "\t"
puts $opts[0..$opts.length].join " "
puts "\tGives help text on action."
when :list
puts "list [entry]"
puts "\tLists all current entries if an entry is not given, else, list all revisions of an entry.."
when :revert
puts "revert entryname rev"
puts "\tReverts entryname to revision rev"
when :view
puts "view entryname [rev]"
puts "\t Views entry with name entryname, and a specific revision rev if requested."
else puts "Unknown action: #{what.to_s}."
end
end
if ARGV.length == 0
help
exit
else
$action = ARGV[0]
$options = ARGV[1..ARGV.length].join(" ")
end
opts = $options.split(" ")
case $action
when ""
help
when "about"
puts "SYmbolic transferrence, and a bit of existential goo"
puts "Is the computer no the platform you have searched for?"
puts "My life is inconclusive, I live to serve you today,"
puts "How may I assist your necessities?"
when "add"
entry = opts[0]
text = ""
if opts.length == 0
puts "Syntax is symbol add (topic-name) [description|file=filename]"
exit
end
if opts.length == 1
STDIN.read.split("\n").each { |line|
text += line + "\n"
}
elsif opts.length == 2
if opts[1] =~ /file=(.*)/
cwd = Dir.pwd
if test ?e,cwd+"/"+$1
f = File.new(pwd+"/"+$1).each { |line|
text += line
}.close
end
end
else
text = opts[1..opts.length].join " "
end
text = $sql.quote(text)
entry = $sql.quote(entry)
date = Time.now.to_i
rev = query("SELECT * FROM symbols WHERE name='#{entry}'").num_rows
begin
query("INSERT INTO symbols (name,body,date,rev) VALUES ('#{entry}','#{text}','#{date}',#{rev})")
puts "Successfully added #{entry}."
rescue Mysql::Error => e
puts "Could not add #{entry} (E#{e.errno}: #{e.error})"
end
when "change"
entry = opts[0]
text = ""
if opts.length == 1
STDIN.read.split("\n").each { |line|
text += line + "\n"
}
else
text = opts[1..opts.length].join " "
end
text = $sql.quote(text)
entry = $sql.quote(entry)
if query("SELECT * FROM symbols WHERE name='#{entry}'").num_rows == 0
puts "Error: that entry does not exist."
exit
end
rev = query("SELECT * FROM symbols WHERE name='#{entry}'").num_rows
begin
query("INSERT INTO symbols (name,body,date,rev) VALUES ('#{entry}','#{text}','#{date}',#{rev})")
puts "Successfully updated #{entry}."
rescue Mysql::Error => e
puts "Could not add #{entry} (E#{e.errno}: #{e.error})"
end
when "delete"
files = Array.new
if opts.length == 0
puts "No entries given. Please enter what entries you want to delete, one line per entry.
Press ctrl+d when done."
STDIN.read.split("\n").each { |file|
files.push file
}
else
files = opts
end
for i in 0..files.length-1
item = files[i]
if item == "*"
puts "SIR I DISAGREE WITH YOUR * ANTICS"
next
end
if item =~ /(.*?)\-rev\=(.*)/i
name = $sql.quote($1)
last = 9999999999999999999
$2.split(/,\s*?/).sort{|x,y| x.to_i <=> y.to_i}.each { |rev|
begin
revert = Integer(rev).to_i
if revert > last
revert = revert - 1
end
if query("SELECT * FROM symbols WHERE name='#{name}'").num_rows == 0
puts "Error: Entry not found: #{name}"
next
end
if query("SELECT * FROM symbols WHERE name='#{name}' AND rev=#{revert}").num_rows == 0
puts "Error: Specific revision #{revert} not found for entry #{name}"
next
end
query("DELETE FROM symbols WHERE name='#{name}' AND rev=#{revert}")
query("UPDATE symbols SET rev=rev-1 WHERE rev > #{revert}")
rescue ArgumentError => e
puts "Error: #{rev} not a number. Skipping."
ensure
last = revert
end
}
else
item = $sql.quote(item)
if query("SELECT * FROM symbols WHERE name='#{item}'").num_rows == 0
puts "Error: Entry not found: #{item}"
exit
end
begin
query("DELETE FROM symbols WHERE name='#{item}'")
puts "Entry deleted (along with all revisions): #{item}"
rescue Mysql::Error
end
end
end
when "help"
$options = "default" if $options == ""
help $options.split(" ")[0].to_sym
when "list"
if opts.length > 0
for i in 0..opts.length-1
k = 0;
name = opts[i]
query("SELECT * FROM symbols WHERE name='#{name}' ORDER BY rev").each_hash { |entry|
next if entry == nil
k+=1
puts "#{entry['name']}, rev #{entry['rev']}: #{entry['body']} ("+Time.at(entry["date"].to_i)+")"
}
puts "No entries found for #{name}" if k == 0;
end
else
list = Hash.new()
i = 0
$sql.query("SELECT * FROM symbols").each_hash { |entry|
next if entry == nil
i+=1;
if list[entry["name"]] == nil
list[entry["name"]] = 0
else
list[entry["name"]] += 1
end
}
if i > 0
list.sort{|a,b| a[0].downcase <=> b[0].downcase}.each { |blk|
puts "#{blk[0]} (rev #{blk[1]})"
}
else
puts "No entries currently found."
end
end
when "revert"
entryname = opts[0]
if entryname == nil
puts "You seem to have missed an entryname."
exit
end
revert = opts[1]
if revert == nil
puts "You seem to have missed the revert number."
exit
end
q = query("SELECT * FROM symbols WHERE name='#{entryname}' AND rev=#{revert}")
if q.num_rows == 0
puts "Error: revert number #{revert} does not exist."
exit
end
text = ""
q.each_hash { |entry|
text = entry["body"]
}
entry = $sql.quote(entryname)
date = Time.now.to_i
rev = query("SELECT * FROM symbols WHERE name='#{entry}'").num_rows
query("INSERT INTO symbols (name,body,date,rev) VALUES ('#{entry}','#{text}','#{date}',#{rev})")
when "view"
entryname = opts[0]
rev = 0;
if entryname == "*"
puts "If you want to view all the topics, try list."
exit
end
if entryname == nil
puts "You forgot to put an entryname in."
exit
end
if opts[1] != nil
begin
rev = Integer(opts[1]).to_i
rescue
puts "I'm sorry, but #{opts[1]} is not an acceptable entry for a number."
exit
end
if rev < 0
puts "Trying to get something that isn't there, I see."
exit
end
else
rev = query("SELECT * FROM symbols WHERE name='#{entryname}'").num_rows
rev -= 1 if rev > 0
end
ename = $sql.quote(entryname)
q = query("SELECT * FROM symbols WHERE name='#{ename}' AND rev=#{rev}")
if q.num_rows == 0
puts "Not found: #{entryname} (REV #{rev})"
else
q.each_hash { |entry|
puts "Entry: "+entry["name"]
puts entry["body"]
puts "(Revision: #{entry["rev"]})"
puts "Entered: "+(Time.at(entry["date"].to_i))
}
end
else puts "#{$action}: not a known action."
end
Comments
ellipsis 12 years ago
Pretty cool. Ruby code is so much fun to read. You're obviously a professional Ruby dev.