naver 0.2.1 → 0.3.1

Sign up to get free protection for your applications and to get access to all the features.
data/CHANGELOG.rdoc CHANGED
@@ -1,17 +1,43 @@
1
+ == 0.3.1, release 2008-12-05
2
+
3
+ * Every search method will no longer return libxml node object. It will return self-defined RSS or Result object.
4
+ * implemented easy access to each element in RSS/XML results by calling instance variables
5
+ * added test file (You can refer this file for understanding usage of this gem.)
6
+ * added documentation files (ri, RDoc)
7
+ * fixed searching for "doc" (The name was overlapped with an instance variable.)
8
+ * revised readme file to remove important note and instruction for installing from github
9
+ * 서치 메소드들이 더 이상 libxml 노드 오브젝트를 반환하지 않습니다. 대신에, 자체 정의된 RSS 또는 Result 오브젝트를 반환합니다.
10
+ * 인스턴스 변수를 쓰는 것으로 RSS/XML 결과들의 각 엘러먼트에 쉽게 접근할 수 있도록 함
11
+ * 테스트 파일 추가 (이 파일을 참조하여 이 젬의 사용법을 이해하실 수 있습니다.)
12
+ * 문서 파일 추가 (ri, RDoc)
13
+ * "doc"에 대해서 검색이 안 되던 것을 고침 (인스턴스 변수와 이름이 중복되어 있었음)
14
+ * Readme 파일을 수정하여 중요 공지를 지우고 github로부터 설치하는 방법을 지움
15
+
16
+
1
17
  == 0.2.1, release 2008-12-04
2
18
 
3
- * converted class Naver to module Naver ("Naver.new" is no longer available) / 클래스에서 모듈로 구조 변경 ("Naver.new"는 더 이상 사용 불가)
4
- * implemented method missing to use search target name as method / 메소드 미싱을 구현하여 검색 타겟을 메소드로 호출할 수 있게 함
5
- * added abbreviation hash for passing arguments / 검색 조건 넘길 때 약어로 넘길 수 있게 함
6
- * added Korean parts of readme and changelog files / readme와 changelog에 한글 부분 추가
7
- * distributed on rubyforge.org as well (originally only available on github) / 루비포지에서도 배포 (원래는 github에만 있었음)
19
+ * converted class Naver to module Naver ("Naver.new" is no longer available)
20
+ * implemented method missing to use search target name as method
21
+ * added abbreviation hash for passing arguments
22
+ * added Korean parts of readme and changelog files
23
+ * distributed on rubyforge.org as well (originally only available on github)
24
+ * 클래스에서 모듈로 구조 변경 ("Naver.new"는 더 이상 사용 불가)
25
+ * 메소드 미싱을 구현하여 검색 타겟을 메소드로 호출할 수 있게 함
26
+ * 검색 조건 넘길 때 약어로 넘길 수 있게 함
27
+ * readme와 changelog에 한글 부분 추가
28
+ * 루비포지에서도 배포 (원래는 github에만 있었음)
8
29
 
9
30
  == 0.1.1, release 2008-11-23
10
31
 
11
- * primitive 'request' method implemented / 원시 'request' 메소드 구현
12
- * added init.rb / init.rb 파일 추가
32
+ * primitive 'request' method implemented
33
+ * added init.rb
34
+ * 원시 'request' 메소드 구현
35
+ * init.rb 파일 추가
36
+
13
37
 
14
38
  == 0.0.1, release 2008-11-22
15
39
 
16
- * first commit / 첫 번째 커밋
17
- * no classes, methods implemented / 아직 아무 것도 안 했음
40
+ * first commit
41
+ * no classes, methods implemented
42
+ * 첫 번째 커밋
43
+ * 아직 아무 것도 안 했음
data/Manifest CHANGED
@@ -1,8 +1,12 @@
1
1
  CHANGELOG.rdoc
2
2
  init.rb
3
3
  lib/naver/base.rb
4
+ lib/naver/item.rb
5
+ lib/naver/result.rb
6
+ lib/naver/rss.rb
4
7
  lib/naver.rb
5
8
  Manifest
6
9
  rakefile
7
10
  README.rdoc
11
+ test/test_naver.rb
8
12
  Rakefile
data/README.rdoc CHANGED
@@ -1,21 +1,14 @@
1
- = Naver 0.2.1
1
+ = Naver 0.3.1
2
2
 
3
3
  Ruby gem for using Naver OpenAPI (http://dev.naver.com/openapi/tutorial).
4
4
  네이버 OpenAPI를 위한 루비젬입니다.
5
5
 
6
6
 
7
- == IMPORTANT NOTE / 중요 공지
8
-
9
- Since this is still in development stage, every method or usage may be deprecated in future versions without any prior notice. (I will try to keep track of changes in CHANGELOG.rdoc, though.)
10
- Although I read the Rational Versioning Policy, I would change the middle number when some old codes might not work well with updates since Naver gem is still in development stage. When this gem considered stable, I will follow the RVP.
11
- 현재 초기 작업 단계이기 때문에, 사전 공지 없이 모든 메소드나 사용법이 미래 버전에서는 사용하게 없게 될 수도 있습니다. (물론 CHANGELOG.rdoc에 변화 사항들을 기록하려고 노력은 하겠습니다만)
12
- Rational Versioning Policy에 대해서 읽기는 했습니다만, 역시 아직 초기 개발 단계라서 과거 버전과 compatible하지 않은 버전을 릴리즈할 경우에 버전의 첫째 자리가 아닌 중간 자리 숫자를 변경할 생각입니다.
13
-
14
-
15
7
  == Install / 설치법
16
8
 
17
- gem sources -a http://gems.github.com
18
- gem install oksure-naver
9
+ You can install the gem from rubyforge directly.
10
+ 루비포지에서 바로 설치하실 수 있습니다.
11
+ gem install naver
19
12
 
20
13
 
21
14
  == Usage / 사용법
@@ -26,11 +19,18 @@ Before using this gem, you need to get your own API key. To obtain your API key,
26
19
  require 'naver'
27
20
  naver = Naver::Base.new(api_key) ### create a naver client / 네이버 클라이언트를 생성합니다
28
21
  naver.request("kin", "go", {:display => "5", :start => "1", :sort => "sim"}) ### return root node as libxml node / libxml 형식의 노드로 루트 노드를 반환합니다
29
- naver.kin("go", {:display => "5", :start => "1", :sort => "sim"}) ### return root node as libxml node / libxml 형식의 노드로 루트 노드를 반환합니다
30
- naver.kin("go", {:d => "5", :start => "5", :so => "sim"}) ### It's possible to use abbreviation for each option / 검색 옵션을 넘길 때 약어를 사용 가능합니다
22
+ naver.kin("go", {:display => "5", :start => "1", :sort => "sim"}) ### return RSS object / 자체 정의된 RSS 클래스 오브젝트를 반환합니다
23
+ naver.kin("go", {:d => "5", :st => "5", :so => "sim"}) ### It's possible to use abbreviation for each option / 검색 옵션을 넘길 때 약어를 사용 가능합니다
24
+ naver.kin("go").lastBuildDate ### return lastBuildDate content in String / 스트링으로 lastBuildDate 값을 반환합니다
25
+ naver.kin("go").items.each do |i| ### items returns array of Item object which contains title, link, and so on.
26
+ puts i.title ### items는 Item 오브젝트의 배열을 반환하고 각 Item 오브젝트 속에 title, link 등이 들어있습니다.
27
+ end
28
+
29
+ You may want to take a look at the test file (test/test_naver.rb) to better understand the usage.
30
+ 보다 자세한 사용법을 이해하시길 원하시면 테스트 파일 (test/test_naver.rb)을 참고하시면 됩니다.
31
31
 
32
32
 
33
- == Abbreviation List / 약어 목록
33
+ == Search Option Abbreviation List / 검색 옵션 약어 목록
34
34
 
35
35
  The full list of abbreviation codes is the following. (You can still use full name of each parameter.)
36
36
  약어 전체 목록을 아래에 정리하였습니다. (약어를 쓰지 않으셔도 작동합니다.)
data/Rakefile CHANGED
@@ -2,13 +2,13 @@ require 'rubygems'
2
2
  require 'rake'
3
3
  require 'echoe'
4
4
 
5
- Echoe.new('naver', '0.2.1') do |p|
5
+ Echoe.new('naver', '0.3.1') do |p|
6
6
  p.description = "Ruby Gem for Naver OpenAPI"
7
7
  p.url = "http://oksurerails.com/naver"
8
8
  p.author = "Hyunwoo Park"
9
9
  p.email = "hwpark@oksurerails.com"
10
10
  p.ignore_pattern = ["tmp/*", "script/*"]
11
- p.development_dependencies = ["libxml-ruby"]
11
+ p.development_dependencies = ["libxml-ruby >=0.9.2"]
12
12
  end
13
13
 
14
14
  Dir["#{File.dirname(__FILE__)}/tasks/*.rake"].sort.each { |ext| load ext }
data/lib/naver.rb CHANGED
@@ -9,25 +9,27 @@
9
9
  # require 'naver'
10
10
  # naver = Naver.new(api_key) ### create a naver client
11
11
  # naver.request("kin", "go", {:display => "5", :start => "1", :sort => "sim"}) ### return root node as libxml node
12
- #
13
- # To Do:
14
- # local search implementation
15
12
 
16
- require "cgi"
17
- require "net/http"
18
- require "libxml"
13
+ %w[cgi net/http libxml].each {|lib| require lib}
19
14
 
20
15
  $:.unshift(File.join(File.dirname(__FILE__)))
16
+
21
17
  require "naver/base"
18
+ require "naver/rss"
19
+ require "naver/result"
20
+ require "naver/item"
22
21
 
23
22
  module Naver
23
+ include LibXML
24
+
24
25
  class NoMethod < StandardError; end
26
+ class NoQuery < StandardError; end
25
27
 
26
28
  # Searches that returns results in RSS format
27
29
  RSS_LIST = %w[kin video image doc book book_adv local shop encyc krdic endic jpdic blog cafe cafearticle webkr news]
28
30
 
29
31
  # Searches that returns results in Non-RSS but XML format
30
- XML_LIST = %w[rank rankthem recmd adult errata shortcut]
32
+ XML_LIST = %w[rank ranktheme recmd adult errata shortcut]
31
33
 
32
34
  # Whole available search list
33
35
  METHOD_LIST = RSS_LIST.concat(XML_LIST)
@@ -36,7 +38,4 @@ module Naver
36
38
  ABBREVIATION = {:d => :display, :st => :start, :so => :sort, :f => :filter, :p => :payment,
37
39
  :dt => :d_titl, :da => :d_auth, :dco => :d_cont, :di => :d_isbn, :dp => :d_publ,
38
40
  :ddaf => :d_dafr, :ddat => :d_dato, :dca => :d_catg}
39
-
40
- SourceName = 'navergem'
41
-
42
41
  end
data/lib/naver/base.rb CHANGED
@@ -1,9 +1,10 @@
1
1
  module Naver
2
- include LibXML
3
2
 
3
+ # fundamental class for naver gem
4
4
  class Base
5
5
 
6
- attr_accessor :doc, :raw_xml
6
+ # attributes for accessing retrieved raw xml and parsed libxml root node
7
+ attr_accessor :doc_root, :raw_xml
7
8
 
8
9
  # Replace this API key with your own (see http://dev.naver.com/openapi/register)
9
10
  def initialize(key=nil)
@@ -13,8 +14,14 @@ module Naver
13
14
  end
14
15
 
15
16
  def method_missing(target, query, params={})
17
+ raise NoQuery if query.empty?
16
18
  if METHOD_LIST.include?(target.to_s)
17
19
  request(target, query, params)
20
+ if XML_LIST.include?(target.to_s)
21
+ return Result.new(@doc_root, target.to_s)
22
+ else
23
+ return RSS.new(@doc_root)
24
+ end
18
25
  else
19
26
  raise NoMethod
20
27
  end
@@ -25,7 +32,7 @@ module Naver
25
32
  response = http_get(request_url(target, query, params))
26
33
  parser, parser.string = LibXML::XML::Parser.new, response
27
34
  @raw_xml = parser.parse
28
- @doc = @raw_xml.root
35
+ @doc_root = @raw_xml.root
29
36
  end
30
37
 
31
38
  # Takes a Naver API method name and set of parameters; returns the correct URL for the REST API.
data/lib/naver/item.rb ADDED
@@ -0,0 +1,16 @@
1
+ module Naver
2
+
3
+ # contains each item's information and converts XML format to Ruby format
4
+ class Item
5
+
6
+ # creates Item class object from libxml node input
7
+ def initialize(doc)
8
+ if cs = doc.children
9
+ cs.each do |c|
10
+ Item.class_eval("attr_accessor :#{c.name}")
11
+ self.instance_variable_set("@#{c.name}", c.content)
12
+ end
13
+ end
14
+ end
15
+ end
16
+ end
@@ -0,0 +1,44 @@
1
+ module Naver
2
+
3
+ # contains Result type return and converts XML format to Ruby format
4
+ class Result
5
+
6
+ # variable for accessing items
7
+ attr_accessor :items
8
+
9
+ # creates Result object from libxml node input
10
+ def initialize(doc_root, target)
11
+ channel = doc_root.find("//result").first
12
+
13
+ case target
14
+ when "rank", "ranktheme":
15
+ Result.class_eval("attr_accessor :ranks")
16
+ @ranks = []
17
+ channel.find("item").first.children.each do |c|
18
+ @ranks << Item.new(c)
19
+ end
20
+ when "recmd":
21
+ Result.class_eval("attr_accessor :recmds")
22
+ @recmds = []
23
+ channel.find("item").each do |i|
24
+ @recmds << i.content
25
+ end
26
+ when "adult", "errata":
27
+ Result.class_eval("attr_accessor :#{target}")
28
+ self.instance_variable_set("@#{target}", channel.find("item/#{target}").first.content)
29
+ when "shortcut":
30
+ Result.class_eval("attr_accessor :shortcuts")
31
+ @shortcuts = []
32
+ channel.find("item/shortcut").each do |s|
33
+ @shortcuts << Item.new(s)
34
+ end
35
+ else
36
+ Result.class_eval("attr_accessor :items")
37
+ @items = []
38
+ channel.find("item").each do |i|
39
+ @items << Item.new(i)
40
+ end
41
+ end
42
+ end
43
+ end
44
+ end
data/lib/naver/rss.rb ADDED
@@ -0,0 +1,23 @@
1
+ module Naver
2
+
3
+ # contains RSS type return and converts XML format to Ruby format
4
+ class RSS
5
+
6
+ # variable for accessing items
7
+ attr_accessor :items
8
+
9
+ # creates RSS class object from libxml node input
10
+ def initialize(doc_root)
11
+ channel = doc_root.find("//rss/channel").first
12
+ %w[lastBuildDate total start display].each do |f|
13
+ RSS.class_eval("attr_accessor :#{f}")
14
+ self.instance_variable_set("@#{f}", channel.find(f).first.content)
15
+ end
16
+
17
+ @items = []
18
+ channel.find("item").each do |i|
19
+ @items << Item.new(i)
20
+ end
21
+ end
22
+ end
23
+ end
data/naver.gemspec CHANGED
@@ -2,15 +2,15 @@
2
2
 
3
3
  Gem::Specification.new do |s|
4
4
  s.name = %q{naver}
5
- s.version = "0.2.1"
5
+ s.version = "0.3.1"
6
6
 
7
7
  s.required_rubygems_version = Gem::Requirement.new(">= 1.2") if s.respond_to? :required_rubygems_version=
8
8
  s.authors = ["Hyunwoo Park"]
9
- s.date = %q{2008-12-04}
9
+ s.date = %q{2008-12-05}
10
10
  s.description = %q{Ruby Gem for Naver OpenAPI}
11
11
  s.email = %q{hwpark@oksurerails.com}
12
- s.extra_rdoc_files = ["CHANGELOG.rdoc", "lib/naver/base.rb", "lib/naver.rb", "README.rdoc"]
13
- s.files = ["CHANGELOG.rdoc", "init.rb", "lib/naver/base.rb", "lib/naver.rb", "Manifest", "rakefile", "README.rdoc", "Rakefile", "naver.gemspec"]
12
+ s.extra_rdoc_files = ["CHANGELOG.rdoc", "lib/naver/base.rb", "lib/naver/item.rb", "lib/naver/result.rb", "lib/naver/rss.rb", "lib/naver.rb", "README.rdoc"]
13
+ s.files = ["CHANGELOG.rdoc", "init.rb", "lib/naver/base.rb", "lib/naver/item.rb", "lib/naver/result.rb", "lib/naver/rss.rb", "lib/naver.rb", "Manifest", "rakefile", "README.rdoc", "test/test_naver.rb", "Rakefile", "naver.gemspec"]
14
14
  s.has_rdoc = true
15
15
  s.homepage = %q{http://oksurerails.com/naver}
16
16
  s.rdoc_options = ["--line-numbers", "--inline-source", "--title", "Naver", "--main", "README.rdoc"]
@@ -18,17 +18,18 @@ Gem::Specification.new do |s|
18
18
  s.rubyforge_project = %q{naver}
19
19
  s.rubygems_version = %q{1.3.1}
20
20
  s.summary = %q{Ruby Gem for Naver OpenAPI}
21
+ s.test_files = ["test/test_naver.rb"]
21
22
 
22
23
  if s.respond_to? :specification_version then
23
24
  current_version = Gem::Specification::CURRENT_SPECIFICATION_VERSION
24
25
  s.specification_version = 2
25
26
 
26
27
  if Gem::Version.new(Gem::RubyGemsVersion) >= Gem::Version.new('1.2.0') then
27
- s.add_development_dependency(%q<libxml-ruby>, [">= 0"])
28
+ s.add_development_dependency(%q<libxml-ruby>, [">= 0.9.2"])
28
29
  else
29
- s.add_dependency(%q<libxml-ruby>, [">= 0"])
30
+ s.add_dependency(%q<libxml-ruby>, [">= 0.9.2"])
30
31
  end
31
32
  else
32
- s.add_dependency(%q<libxml-ruby>, [">= 0"])
33
+ s.add_dependency(%q<libxml-ruby>, [">= 0.9.2"])
33
34
  end
34
35
  end
data/rakefile CHANGED
@@ -2,13 +2,13 @@ require 'rubygems'
2
2
  require 'rake'
3
3
  require 'echoe'
4
4
 
5
- Echoe.new('naver', '0.2.1') do |p|
5
+ Echoe.new('naver', '0.3.1') do |p|
6
6
  p.description = "Ruby Gem for Naver OpenAPI"
7
7
  p.url = "http://oksurerails.com/naver"
8
8
  p.author = "Hyunwoo Park"
9
9
  p.email = "hwpark@oksurerails.com"
10
10
  p.ignore_pattern = ["tmp/*", "script/*"]
11
- p.development_dependencies = ["libxml-ruby"]
11
+ p.development_dependencies = ["libxml-ruby >=0.9.2"]
12
12
  end
13
13
 
14
14
  Dir["#{File.dirname(__FILE__)}/tasks/*.rake"].sort.each { |ext| load ext }
@@ -0,0 +1,105 @@
1
+ # == IMPORTANT!
2
+ # This test consumes about 75 query quota of your API key.
3
+ # == 중요!
4
+ # 이 테스트 파일은 사용자 API Key에 할당된 분량 중, 약 75회 정도의 쿼리 수량을 소모합니다.
5
+
6
+ $:.unshift File.join(File.dirname(__FILE__),'..','lib')
7
+
8
+ require 'test/unit'
9
+ require 'naver'
10
+
11
+ class TestNaver < Test::Unit::TestCase
12
+
13
+ # sets up basic setting for unit testing
14
+ def setup
15
+ # insert your own Naver API key
16
+ @n = Naver::Base.new('your_key')
17
+ end
18
+
19
+ # tests if all methods are working fine
20
+ def test_allmethod
21
+ # all methods returning RSS format document
22
+ r = @n.kin("go"); puts r # This shows you the basic usage clear.
23
+ %w[kin video image doc book book_adv local shop encyc krdic endic jpdic blog cafe cafearticle webkr news].each do |m|
24
+ instance_eval("assert_kind_of(Naver::RSS, r = @n.#{m}('go'))"); puts r
25
+ end
26
+
27
+ # all methods returning <result> format XML document
28
+ %w[nexearch cafe blog dic image kin music video webkr site news].each do |q|
29
+ assert_kind_of(Naver::Result, r = @n.rank(q)); puts r # Select one from "nexearch, cafe, blog, dic, image, kin, music, video, webkr, site, news"
30
+ end
31
+ %w[movie schedulemovie runningmovie people singer foreignsinger talent actor foreignactor entertainer broadcaster comedian sportsstar soccer foreignsoccer drama broadcast game perform book university].each do |q|
32
+ assert_kind_of(Naver::Result, r = @n.ranktheme(q)); puts r # Select one from "movie, schedulemovie, runningmovie, people, singer, foreignsinger, talent, actor, foreignactor, entertainer, broadcaster, comedian, sportsstar, soccer, foreignsoccer, drama, broadcast, game, perform, book, university"
33
+ end
34
+ %w[recmd adult errata shortcut].each do |m|
35
+ instance_eval("assert_kind_of(Naver::Result, r = @n.#{m}('go'))"); puts r
36
+ end
37
+ end
38
+
39
+ # tests is abbreviations for search options are working fine
40
+ def test_abbreviation
41
+ r1 = @n.kin("go", {:display => "5", :start => "6", :sort => "sim"})
42
+ r2 = @n.kin("go", {:d => "5", :st => "6", :so => "sim"})
43
+ assert_equal(5, r1.items.length) # for checking display
44
+ assert_equal(5, r2.items.length) # for checking display
45
+ assert_equal(r1.items[0].title, r2.items[0].title) # for checking start, sort
46
+ puts r1.items.length.to_s + " " + r2.items.length.to_s
47
+ puts r1.items[0].title + " " + r2.items[0].title
48
+
49
+ r1 = @n.video("go", {:filter => "high", :payment => "charge"})
50
+ r2 = @n.video("go", {:f => "high", :p => "charge"})
51
+ assert_equal(r1.items.length, r2.items.length) # for checking filter, payment
52
+ puts r1.items.length.to_s + " " + r2.items.length.to_s
53
+ end
54
+
55
+ # tests if all output fields looks fine
56
+ def test_alloutput
57
+ @a_kin = %w[title link description]
58
+ @a_video = %w[thumbnail]
59
+ @a_image = %w[sizeheight sizewidth]
60
+ @a_book = %w[image author price discount publisher pubdate isbn]
61
+ @a_local = %w[telephone address mapx mapy]
62
+ @a_shop = %w[lprice hprice]
63
+ @a_blog = %w[bloggername bloggerlink]
64
+ @a_cafe = %w[ranking member totalarticles newarticles]
65
+ @a_cafearticle = %w[cafename cafeurl]
66
+ @a_news = %w[originallink pubDate]
67
+
68
+ r, rr = @n.kin("go"), nil
69
+ %w[lastBuildDate total start display].each do |f|
70
+ instance_eval("assert_kind_of(String, rr = r.#{f})"); puts rr
71
+ end
72
+
73
+ %w[kin video image book local shop blog cafe cafearticle news].each do |s|
74
+ instance_eval("r = @n.#{s}('go')")
75
+ self.instance_variable_get("@a_#{s}").each do |f|
76
+ instance_eval("assert_kind_of(String, rr = r.items[0].#{f})"); puts rr
77
+ end
78
+ end
79
+
80
+ r = @n.rank("nexearch")
81
+ assert_kind_of(String, rr = r.ranks[0].K); puts rr
82
+ assert_kind_of(String, rr = r.ranks[0].S); puts rr
83
+ assert_kind_of(String, rr = r.ranks[0].V); puts rr
84
+
85
+ r = @n.ranktheme("movie")
86
+ assert_kind_of(String, rr = r.ranks[0].K); puts rr
87
+ assert_kind_of(String, rr = r.ranks[0].S); puts rr
88
+ assert_kind_of(String, rr = r.ranks[0].V); puts rr
89
+
90
+ r = @n.recmd("spdlqj")
91
+ assert_kind_of(String, rr = r.recmds[0]); puts rr
92
+
93
+ r = @n.adult("go")
94
+ assert_kind_of(String, rr = r.adult); puts rr
95
+
96
+ r = @n.errata("go")
97
+ assert_kind_of(String, rr = r.errata); puts rr
98
+
99
+ r = @n.shortcut("naver")
100
+ assert_kind_of(String, rr = r.shortcuts[0].label); puts rr
101
+ assert_kind_of(String, rr = r.shortcuts[0].url); puts rr
102
+
103
+ end
104
+
105
+ end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: naver
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.1
4
+ version: 0.3.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Hyunwoo Park
@@ -9,7 +9,7 @@ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
11
 
12
- date: 2008-12-04 00:00:00 -08:00
12
+ date: 2008-12-05 00:00:00 -08:00
13
13
  default_executable:
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
@@ -20,7 +20,7 @@ dependencies:
20
20
  requirements:
21
21
  - - ">="
22
22
  - !ruby/object:Gem::Version
23
- version: "0"
23
+ version: 0.9.2
24
24
  version:
25
25
  description: Ruby Gem for Naver OpenAPI
26
26
  email: hwpark@oksurerails.com
@@ -31,16 +31,23 @@ extensions: []
31
31
  extra_rdoc_files:
32
32
  - CHANGELOG.rdoc
33
33
  - lib/naver/base.rb
34
+ - lib/naver/item.rb
35
+ - lib/naver/result.rb
36
+ - lib/naver/rss.rb
34
37
  - lib/naver.rb
35
38
  - README.rdoc
36
39
  files:
37
40
  - CHANGELOG.rdoc
38
41
  - init.rb
39
42
  - lib/naver/base.rb
43
+ - lib/naver/item.rb
44
+ - lib/naver/result.rb
45
+ - lib/naver/rss.rb
40
46
  - lib/naver.rb
41
47
  - Manifest
42
48
  - rakefile
43
49
  - README.rdoc
50
+ - test/test_naver.rb
44
51
  - Rakefile
45
52
  - naver.gemspec
46
53
  has_rdoc: true
@@ -74,5 +81,5 @@ rubygems_version: 1.3.1
74
81
  signing_key:
75
82
  specification_version: 2
76
83
  summary: Ruby Gem for Naver OpenAPI
77
- test_files: []
78
-
84
+ test_files:
85
+ - test/test_naver.rb