summaryrefslogtreecommitdiffstats
path: root/lib/puppet/external/gratr/graph_api.rb
diff options
context:
space:
mode:
authorLuke Kanies <luke@madstop.com>2008-01-07 19:24:10 -0600
committerLuke Kanies <luke@madstop.com>2008-01-07 19:24:10 -0600
commit40addcd1920b0fa2f558c415e65ea665bac812f9 (patch)
treed2792c1d8c84d2cfaed6b48a4642d3ef29ba79c9 /lib/puppet/external/gratr/graph_api.rb
parent927dff41df8f1c236c54eaee9fa1db7a3efaf02a (diff)
downloadpuppet-40addcd1920b0fa2f558c415e65ea665bac812f9.tar.gz
puppet-40addcd1920b0fa2f558c415e65ea665bac812f9.tar.xz
puppet-40addcd1920b0fa2f558c415e65ea665bac812f9.zip
Fixing #982 -- I have completely removed the GRATR graph library
from the system, and implemented my own topsort method.
Diffstat (limited to 'lib/puppet/external/gratr/graph_api.rb')
-rw-r--r--lib/puppet/external/gratr/graph_api.rb83
1 files changed, 0 insertions, 83 deletions
diff --git a/lib/puppet/external/gratr/graph_api.rb b/lib/puppet/external/gratr/graph_api.rb
deleted file mode 100644
index 26d18958a..000000000
--- a/lib/puppet/external/gratr/graph_api.rb
+++ /dev/null
@@ -1,83 +0,0 @@
-#--
-# Copyright (c) 2006 Shawn Patrick Garbett
-# Copyright (c) 2002,2004,2005 by Horst Duchene
-#
-# Redistribution and use in source and binary forms, with or without modification,
-# are permitted provided that the following conditions are met:
-#
-# * Redistributions of source code must retain the above copyright notice(s),
-# this list of conditions and the following disclaimer.
-# * Redistributions in binary form must reproduce the above copyright notice,
-# this list of conditions and the following disclaimer in the documentation
-# and/or other materials provided with the distribution.
-# * Neither the name of the Shawn Garbett nor the names of its contributors
-# may be used to endorse or promote products derived from this software
-# without specific prior written permission.
-#
-# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
-# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
-# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
-# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
-# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
-# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
-# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
-# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
-# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-#++
-
-
-module GRATR
-
- # This defines the minimum set of functions required to make a graph class that can
- # use the algorithms defined by this library
- module GraphAPI
-
- # Is the graph directed?
- #
- # This method must be implemented by the specific graph class
- def directed?() raise NotImplementedError; end
-
- # Add a vertex to the Graph and return the Graph
- # An additional label l can be specified as well
- #
- # This method must be implemented by the specific graph class
- def add_vertex!(v,l=nil) raise NotImplementedError; end
-
- # Add an edge to the Graph and return the Graph
- # u can be an object of type GRATR::Edge or u,v specifies
- # a source, target pair. The last parameter is an optional label
- #
- # This method must be implemented by the specific graph class
- def add_edge!(u,v=nil,l=nil) raise NotImplementedError; end
-
- # Remove a vertex to the Graph and return the Graph
- #
- # This method must be implemented by the specific graph class
- def remove_vertex!(v) raise NotImplementedError; end
-
- # Remove an edge from the Graph and return the Graph
- #
- # Can be a type of GRATR::Edge or a source and target
- # This method must be implemented by the specific graph class
- def remove_edge!(u,v=nil) raise NotImplementedError; end
-
- # Return the array of vertices.
- #
- # This method must be implemented by the specific graph class
- def vertices() raise NotImplementedError; end
-
- # Return the array of edges.
- #
- # This method must be implemented by the specific graph class
- def edges() raise NotImplementedError; end
-
- # Returns the edge class
- def edge_class() raise NotImplementedError; end
-
- # Return the chromatic number for this graph
- # This is currently incomplete and in some cases will be NP-complete
- # FIXME: Should this even be here? My gut feeling is no...
- def chromatic_number() raise NotImplementedError; end
- end
-end \ No newline at end of file