khayyam 0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- data/History.txt +6 -0
- data/Manifest.txt +13 -0
- data/README.txt +107 -0
- data/Rakefile +14 -0
- data/features/export.feature +17 -0
- data/features/import.feature +11 -0
- data/features/steps/export_steps.rb +46 -0
- data/features/steps/import_steps.rb +25 -0
- data/lib/khayyam.rb +8 -0
- data/lib/topic.rb +53 -0
- data/spec/spec.opts +1 -0
- data/spec/spec_helper.rb +10 -0
- data/spec/topic_spec.rb +37 -0
- metadata +78 -0
data/History.txt
ADDED
data/Manifest.txt
ADDED
@@ -0,0 +1,13 @@
|
|
1
|
+
History.txt
|
2
|
+
Manifest.txt
|
3
|
+
README.txt
|
4
|
+
Rakefile
|
5
|
+
features/export.feature
|
6
|
+
features/import.feature
|
7
|
+
features/steps/export_steps.rb
|
8
|
+
features/steps/import_steps.rb
|
9
|
+
lib/khayyam.rb
|
10
|
+
lib/topic.rb
|
11
|
+
spec/spec.opts
|
12
|
+
spec/spec_helper.rb
|
13
|
+
spec/topic_spec.rb
|
data/README.txt
ADDED
@@ -0,0 +1,107 @@
|
|
1
|
+
= khayyam
|
2
|
+
|
3
|
+
* http://khayyam.rubyforge.org
|
4
|
+
|
5
|
+
== DESCRIPTION:
|
6
|
+
|
7
|
+
A gem for easily moving data and definititions, such as vocabulary words and definitions to and from files
|
8
|
+
|
9
|
+
== FEATURES/PROBLEMS:
|
10
|
+
|
11
|
+
* See SYNOPSIS.
|
12
|
+
|
13
|
+
== SYNOPSIS:
|
14
|
+
|
15
|
+
Export data to a string
|
16
|
+
|
17
|
+
Example:
|
18
|
+
topic = Khayyam::Topic.new "vi"
|
19
|
+
topic.regarding "movement" do |items|
|
20
|
+
items["h"] = "left"
|
21
|
+
items["j"] = "up"
|
22
|
+
end
|
23
|
+
topic.regarding "commands" do |items|
|
24
|
+
items[":q"] = "quit"
|
25
|
+
items[":x"] = "save and quit"
|
26
|
+
end
|
27
|
+
output_string = topic.export
|
28
|
+
|
29
|
+
|
30
|
+
Import data from a string.
|
31
|
+
|
32
|
+
Example:
|
33
|
+
topic = Khayyam::Topic.import my_data
|
34
|
+
topic.regarding "foo" do |facts|
|
35
|
+
puts facts["bar"]
|
36
|
+
end
|
37
|
+
|
38
|
+
=> "monkey"
|
39
|
+
|
40
|
+
== REQUIREMENTS:
|
41
|
+
|
42
|
+
* N/A
|
43
|
+
|
44
|
+
== INSTALL:
|
45
|
+
|
46
|
+
* sudo gem install khayyam
|
47
|
+
|
48
|
+
== LICENSE:
|
49
|
+
|
50
|
+
(The Ruby License)
|
51
|
+
|
52
|
+
Copyright (c) 2008 Jamal Hansen
|
53
|
+
|
54
|
+
Khayyam is copyrighted free software by Jamal Hansen
|
55
|
+
<jamal.hansen at gmail dot com> and contributors. You can redistribute it and/or
|
56
|
+
modify it under either the terms of the GPL2 or the conditions below:
|
57
|
+
|
58
|
+
1. You may make and give away verbatim copies of the source form of the
|
59
|
+
software without restriction, provided that you duplicate all of the
|
60
|
+
original copyright notices and associated disclaimers.
|
61
|
+
|
62
|
+
2. You may modify your copy of the software in any way, provided that
|
63
|
+
you do at least ONE of the following:
|
64
|
+
|
65
|
+
a) place your modifications in the Public Domain or otherwise make them
|
66
|
+
Freely Available, such as by posting said modifications to Usenet or an
|
67
|
+
equivalent medium, or by allowing the author to include your
|
68
|
+
modifications in the software.
|
69
|
+
|
70
|
+
b) use the modified software only within your corporation or
|
71
|
+
organization.
|
72
|
+
|
73
|
+
c) rename any non-standard executables so the names do not conflict with
|
74
|
+
standard executables, which must also be provided.
|
75
|
+
|
76
|
+
d) make other distribution arrangements with the author.
|
77
|
+
|
78
|
+
3. You may distribute the software in object code or executable
|
79
|
+
form, provided that you do at least ONE of the following:
|
80
|
+
|
81
|
+
a) distribute the executables and library files of the software,
|
82
|
+
together with instructions (in the manual page or equivalent) on where
|
83
|
+
to get the original distribution.
|
84
|
+
|
85
|
+
b) accompany the distribution with the machine-readable source of the
|
86
|
+
software.
|
87
|
+
|
88
|
+
c) give non-standard executables non-standard names, with
|
89
|
+
instructions on where to get the original software distribution.
|
90
|
+
|
91
|
+
d) make other distribution arrangements with the author.
|
92
|
+
|
93
|
+
4. You may modify and include the part of the software into any other
|
94
|
+
software (possibly commercial). But some files in the distribution
|
95
|
+
are not written by the author, so that they are not under this terms.
|
96
|
+
|
97
|
+
5. The scripts and library files supplied as input to or produced as
|
98
|
+
output from the software do not automatically fall under the
|
99
|
+
copyright of the software, but belong to whomever generated them,
|
100
|
+
and may be sold commercially, and may be aggregated with this
|
101
|
+
software.
|
102
|
+
|
103
|
+
6. THIS SOFTWARE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR
|
104
|
+
IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
|
105
|
+
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
106
|
+
PURPOSE.
|
107
|
+
|
data/Rakefile
ADDED
@@ -0,0 +1,14 @@
|
|
1
|
+
# -*- ruby -*-
|
2
|
+
require 'rubygems'
|
3
|
+
require 'hoe'
|
4
|
+
require 'cucumber/rake/task'
|
5
|
+
require './lib/khayyam.rb'
|
6
|
+
|
7
|
+
Hoe.new('khayyam', Khayyam::VERSION) do |p|
|
8
|
+
p.developer('Jamal Hansen', 'jamal.hansen@gmail.com')
|
9
|
+
p.changes=p.paragraphs_of("History.txt", 0..1).join("\n\n")
|
10
|
+
end
|
11
|
+
|
12
|
+
Cucumber::Rake::Task.new
|
13
|
+
|
14
|
+
# vim: syntax=Ruby
|
@@ -0,0 +1,17 @@
|
|
1
|
+
Story: Exporting a single file
|
2
|
+
As a user of Khayyam
|
3
|
+
I want to export a file with khayyam
|
4
|
+
So that I can use the data elsewhere
|
5
|
+
|
6
|
+
Scenario: Export a file containing a single category
|
7
|
+
Given an object containing data to export
|
8
|
+
When I tell khayaam to export the file
|
9
|
+
Then it will export the file
|
10
|
+
And it will contain all the data in the original objects
|
11
|
+
|
12
|
+
Scenario: Export a file containing multiple categories
|
13
|
+
Given an object containing multiple categories to export
|
14
|
+
When I tell khayaam to export the file
|
15
|
+
Then it will export the file
|
16
|
+
And it will contain all the data and categories in the original objects
|
17
|
+
|
@@ -0,0 +1,11 @@
|
|
1
|
+
Story: Importing a string
|
2
|
+
As a user of Khayyam
|
3
|
+
I want to import a string with khayyam
|
4
|
+
So that I can use it with my application
|
5
|
+
|
6
|
+
Scenario: Import a string containing a single category
|
7
|
+
Given a string containing data to import
|
8
|
+
When I tell khayaam to import the string
|
9
|
+
Then it will import the string into khayyam
|
10
|
+
And it will contain all the data in the string
|
11
|
+
|
@@ -0,0 +1,46 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), *%w[.. .. spec spec_helper.rb])
|
2
|
+
|
3
|
+
Given /^an object containing data to export$/ do
|
4
|
+
@topic = Khayyam::Topic.new "vi"
|
5
|
+
@topic.regarding "movement" do |items|
|
6
|
+
items["h"] = "left"
|
7
|
+
items["j"] = "up"
|
8
|
+
items["k"] = "down"
|
9
|
+
items["l"] = "right"
|
10
|
+
items["^"] = "beginning of line"
|
11
|
+
items["$"] = "end of line"
|
12
|
+
items["w"] = "beginning of next word"
|
13
|
+
end
|
14
|
+
end
|
15
|
+
|
16
|
+
When /^I tell khayaam to export the file$/ do
|
17
|
+
@output = @topic.export
|
18
|
+
end
|
19
|
+
|
20
|
+
Then /^it will export the file$/ do
|
21
|
+
@output.should_not eql(nil)
|
22
|
+
end
|
23
|
+
|
24
|
+
Then /^it will contain all the data in the original objects$/ do
|
25
|
+
@output.should eql("topic: vi\ncategories: \n movement: \n k: down\n w: beginning of next word\n l: right\n $: end of line\n ^: beginning of line\n h: left\n j: up\n")
|
26
|
+
end
|
27
|
+
|
28
|
+
Given /^an object containing multiple categories to export$/ do
|
29
|
+
@topic = Khayyam::Topic.new "vi"
|
30
|
+
@topic.regarding "movement" do |items|
|
31
|
+
items["h"] = "left"
|
32
|
+
items["j"] = "up"
|
33
|
+
end
|
34
|
+
@topic.regarding "commands" do |items|
|
35
|
+
items[":q"] = "quit"
|
36
|
+
items[":x"] = "save and quit"
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
Then /^it will contain all the data and categories in the original objects$/ do
|
41
|
+
@output.should eql(%{topic: vi\ncategories: \n movement: \n h: left\n j: up\n commands: \n \":q\": quit\n \":x\": save and quit\n})
|
42
|
+
end
|
43
|
+
|
44
|
+
|
45
|
+
|
46
|
+
|
@@ -0,0 +1,25 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), *%w[.. .. spec spec_helper.rb])
|
2
|
+
|
3
|
+
Given /^a string containing data to import$/ do
|
4
|
+
@data = "topic: dairy\ncategories:\n cheese:\n cheddar: ubiquitous\n blue: crumbly"
|
5
|
+
end
|
6
|
+
|
7
|
+
When /^I tell khayaam to import the string$/ do
|
8
|
+
@topic = Khayyam::Topic.import @data
|
9
|
+
end
|
10
|
+
|
11
|
+
Then /^it will import the string into khayyam$/ do
|
12
|
+
@topic.class.should eql(Khayyam::Topic)
|
13
|
+
end
|
14
|
+
|
15
|
+
Then /^it will contain all the data in the string$/ do
|
16
|
+
@topic.name.should eql("dairy")
|
17
|
+
@topic.categories.should eql(["cheese"])
|
18
|
+
@topic.regarding("cheese") do |fact|
|
19
|
+
fact["cheddar"].should eql("ubiquitous")
|
20
|
+
fact["blue"].should eql("crumbly")
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
|
25
|
+
|
data/lib/khayyam.rb
ADDED
data/lib/topic.rb
ADDED
@@ -0,0 +1,53 @@
|
|
1
|
+
require 'yaml'
|
2
|
+
|
3
|
+
module Khayyam
|
4
|
+
|
5
|
+
#= Overview
|
6
|
+
# Khayyam::Topic: The class for interacting with topic pairs.
|
7
|
+
#
|
8
|
+
class Topic
|
9
|
+
attr_reader :name
|
10
|
+
|
11
|
+
def initialize name, facts={}
|
12
|
+
@name = name
|
13
|
+
@facts = facts
|
14
|
+
end
|
15
|
+
|
16
|
+
# returns an array of sub-topics
|
17
|
+
def categories
|
18
|
+
@facts.keys
|
19
|
+
end
|
20
|
+
|
21
|
+
# used to work with sub-topics
|
22
|
+
def regarding category
|
23
|
+
@facts[category] ||= {}
|
24
|
+
yield @facts[category]
|
25
|
+
end
|
26
|
+
|
27
|
+
# Export data to a string
|
28
|
+
# Example:
|
29
|
+
# topic = Khayyam::Topic.new "vi"
|
30
|
+
# topic.regarding "movement" do |items|
|
31
|
+
# items["h"] = "left"
|
32
|
+
# items["j"] = "up"
|
33
|
+
# end
|
34
|
+
# topic.regarding "commands" do |items|
|
35
|
+
# items[":q"] = "quit"
|
36
|
+
# items[":x"] = "save and quit"
|
37
|
+
# end
|
38
|
+
# output_string = topic.export
|
39
|
+
def export
|
40
|
+
output = YAML.dump_stream({'topic' => @name, 'categories' => @facts})
|
41
|
+
output[5..output.length]
|
42
|
+
end
|
43
|
+
|
44
|
+
# Import data from a string.
|
45
|
+
#
|
46
|
+
# Example:
|
47
|
+
# topic = Khayyam::Topic.import my_data
|
48
|
+
def self.import string
|
49
|
+
data = YAML.load "--- \n#{string}"
|
50
|
+
khayyam = Khayyam::Topic.new data["topic"], data["categories"]
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
data/spec/spec.opts
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
--colour
|
data/spec/spec_helper.rb
ADDED
data/spec/topic_spec.rb
ADDED
@@ -0,0 +1,37 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), 'spec_helper.rb')
|
2
|
+
|
3
|
+
describe Khayyam::Topic do
|
4
|
+
it "should take the topic as a string on creation" do
|
5
|
+
topic = Khayyam::Topic.new "foo"
|
6
|
+
topic.name.should eql("foo")
|
7
|
+
end
|
8
|
+
|
9
|
+
it "should store topics and facts" do
|
10
|
+
topic = Khayyam::Topic.new "dairy"
|
11
|
+
topic.regarding "cheese" do |fact|
|
12
|
+
fact["cheddar"] = "ubiquitous"
|
13
|
+
end
|
14
|
+
|
15
|
+
topic.categories.should eql(["cheese"])
|
16
|
+
topic.regarding "cheese" do |fact|
|
17
|
+
fact["cheddar"].should eql("ubiquitous")
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
it "should export data to a YAML string" do
|
22
|
+
topic = Khayyam::Topic.new "dairy"
|
23
|
+
topic.regarding "cheese" do |fact|
|
24
|
+
fact["cheddar"] = "ubiquitous"
|
25
|
+
end
|
26
|
+
|
27
|
+
output = topic.export
|
28
|
+
output.should eql("topic: dairy\ncategories: \n cheese: \n cheddar: ubiquitous\n")
|
29
|
+
end
|
30
|
+
|
31
|
+
it "should import data from a YAML string" do
|
32
|
+
topic = Khayyam::Topic.import "topic: dairy\ncategories: \n cheese: \n cheddar: ubiquitous\n"
|
33
|
+
topic.name.should eql("dairy")
|
34
|
+
#topic.
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
metadata
ADDED
@@ -0,0 +1,78 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: khayyam
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 0.0.1
|
5
|
+
platform: ruby
|
6
|
+
authors:
|
7
|
+
- Jamal Hansen
|
8
|
+
autorequire:
|
9
|
+
bindir: bin
|
10
|
+
cert_chain: []
|
11
|
+
|
12
|
+
date: 2008-12-22 00:00:00 -06:00
|
13
|
+
default_executable:
|
14
|
+
dependencies:
|
15
|
+
- !ruby/object:Gem::Dependency
|
16
|
+
name: hoe
|
17
|
+
type: :development
|
18
|
+
version_requirement:
|
19
|
+
version_requirements: !ruby/object:Gem::Requirement
|
20
|
+
requirements:
|
21
|
+
- - ">="
|
22
|
+
- !ruby/object:Gem::Version
|
23
|
+
version: 1.8.2
|
24
|
+
version:
|
25
|
+
description: A gem for easily moving data and definititions, such as vocabulary words and definitions to and from files
|
26
|
+
email:
|
27
|
+
- jamal.hansen@gmail.com
|
28
|
+
executables: []
|
29
|
+
|
30
|
+
extensions: []
|
31
|
+
|
32
|
+
extra_rdoc_files:
|
33
|
+
- History.txt
|
34
|
+
- Manifest.txt
|
35
|
+
- README.txt
|
36
|
+
files:
|
37
|
+
- History.txt
|
38
|
+
- Manifest.txt
|
39
|
+
- README.txt
|
40
|
+
- Rakefile
|
41
|
+
- features/export.feature
|
42
|
+
- features/import.feature
|
43
|
+
- features/steps/export_steps.rb
|
44
|
+
- features/steps/import_steps.rb
|
45
|
+
- lib/khayyam.rb
|
46
|
+
- lib/topic.rb
|
47
|
+
- spec/spec.opts
|
48
|
+
- spec/spec_helper.rb
|
49
|
+
- spec/topic_spec.rb
|
50
|
+
has_rdoc: true
|
51
|
+
homepage: http://khayyam.rubyforge.org
|
52
|
+
post_install_message:
|
53
|
+
rdoc_options:
|
54
|
+
- --main
|
55
|
+
- README.txt
|
56
|
+
require_paths:
|
57
|
+
- lib
|
58
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
59
|
+
requirements:
|
60
|
+
- - ">="
|
61
|
+
- !ruby/object:Gem::Version
|
62
|
+
version: "0"
|
63
|
+
version:
|
64
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
65
|
+
requirements:
|
66
|
+
- - ">="
|
67
|
+
- !ruby/object:Gem::Version
|
68
|
+
version: "0"
|
69
|
+
version:
|
70
|
+
requirements: []
|
71
|
+
|
72
|
+
rubyforge_project: khayyam
|
73
|
+
rubygems_version: 1.2.0
|
74
|
+
signing_key:
|
75
|
+
specification_version: 2
|
76
|
+
summary: A gem for easily moving data and definititions, such as vocabulary words and definitions to and from files
|
77
|
+
test_files: []
|
78
|
+
|