//////////////////////////////////////////////////////////////////////////////// /// @brief JavaScript actions functions /// /// @file /// /// DISCLAIMER /// /// Copyright 2010-2011 triagens GmbH, Cologne, Germany /// /// Licensed under the Apache License, Version 2.0 (the "License"); /// you may not use this file except in compliance with the License. /// You may obtain a copy of the License at /// /// http://www.apache.org/licenses/LICENSE-2.0 /// /// Unless required by applicable law or agreed to in writing, software /// distributed under the License is distributed on an "AS IS" BASIS, /// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. /// See the License for the specific language governing permissions and /// limitations under the License. /// /// Copyright holder is triAGENS GmbH, Cologne, Germany /// /// @author Dr. Frank Celler /// @author Copyright 2011, triAGENS GmbH, Cologne, Germany //////////////////////////////////////////////////////////////////////////////// var internal = require("internal"); var db = internal.db; var edges = internal.edges; var AvocadoCollection = internal.AvocadoCollection; var AvocadoEdgesCollection = internal.AvocadoEdgesCollection; // ----------------------------------------------------------------------------- // --SECTION-- EDGE // ----------------------------------------------------------------------------- // ----------------------------------------------------------------------------- // --SECTION-- constructors and destructors // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup AvocadoGraph /// @{ //////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// /// @brief constructs a new edge object //////////////////////////////////////////////////////////////////////////////// function Edge (graph, id) { var props; this._graph = graph; this._id = id; props = this._graph._edges.document(this._id); // extract the custom identifier, label, edges if (props) { this._eid = props.$eid; this._label = props.$label; this._from = props._from; this._to = props._to; } // deleted else { this._id = undefined; } } //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- public functions // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup AvocadoGraph /// @{ //////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// /// @brief returns the identifier of an edge /// /// @FUN{@FA{edge}.getId()} /// /// Returns the identifier of the @FA{edge}. /// /// @EXAMPLES /// /// @verbinclude graph13 //////////////////////////////////////////////////////////////////////////////// Edge.prototype.getId = function (name) { return this._eid; } //////////////////////////////////////////////////////////////////////////////// /// @brief returns the to vertex /// /// @FUN{@FA{edge}.getInVertex()} /// /// Returns the vertex at the head of the @FA{edge}. /// /// @EXAMPLES /// /// @verbinclude graph21 //////////////////////////////////////////////////////////////////////////////// Edge.prototype.getInVertex = function () { if (! this._id) { throw "accessing a deleted edge"; } return this._graph.constructVertex(this._to); } //////////////////////////////////////////////////////////////////////////////// /// @brief label of an edge /// /// @FUN{@FA{edge}.getLabel()} /// /// Returns the label of the @FA{edge}. /// /// @EXAMPLES /// /// @verbinclude graph20 //////////////////////////////////////////////////////////////////////////////// Edge.prototype.getLabel = function () { if (! this._id) { throw "accessing a deleted edge"; } return this._label; } //////////////////////////////////////////////////////////////////////////////// /// @brief returns the from vertex /// /// @FUN{@FA{edge}.getOutVertex()} /// /// Returns the vertex at the tail of the @FA{edge}. /// /// @EXAMPLES /// /// @verbinclude graph22 //////////////////////////////////////////////////////////////////////////////// Edge.prototype.getOutVertex = function () { if (! this._id) { throw "accessing a deleted edge"; } return this._graph.constructVertex(this._from); } //////////////////////////////////////////////////////////////////////////////// /// @brief returns a property of an edge /// /// @FUN{@FA{edge}.getProperty(@FA{name})} /// /// Returns the property @FA{name} an @FA{edge}. /// /// @EXAMPLES /// /// @verbinclude graph12 //////////////////////////////////////////////////////////////////////////////// Edge.prototype.getProperty = function (name) { if (! this._id) { throw "accessing a deleted edge"; } return this.properties()[name]; } //////////////////////////////////////////////////////////////////////////////// /// @brief gets all property names of an edge /// /// @FUN{@FA{edge}.getPropertyKeys()} /// /// Returns all propety names an @FA{edge}. /// /// @EXAMPLES /// /// @verbinclude graph32 //////////////////////////////////////////////////////////////////////////////// Edge.prototype.getPropertyKeys = function () { if (! this._id) { throw "accessing a deleted edge"; } return propertyKeys(this.properties()); } //////////////////////////////////////////////////////////////////////////////// /// @brief changes a property of an edge /// /// @FUN{@FA{edge}.setProperty(@FA{name}, @FA{value})} /// /// Changes or sets the property @FA{name} an @FA{edges} to @FA{value}. /// /// @EXAMPLES /// /// @verbinclude graph14 //////////////////////////////////////////////////////////////////////////////// Edge.prototype.setProperty = function (name, value) { var props; var shallow; if (! this._id) { throw "accessing a deleted edge"; } props = this._graph._edges.document(this._id); // TODO use "update" if (props !== undefined) { shallow = shallowCopy(props); shallow[name] = value; this._graph._edges.replace(this._id, shallow); return value; } else { return undefined; } } //////////////////////////////////////////////////////////////////////////////// /// @brief returns all properties of an edge /// /// @FUN{@FA{edge}.properties()} /// /// Returns all properties and their values of an @FA{edge} /// /// @EXAMPLES /// /// @verbinclude graph11 //////////////////////////////////////////////////////////////////////////////// Edge.prototype.properties = function () { var result; if (! this._id) { throw "accessing a deleted edge"; } props = this._graph._edges.document(this._id); if (! props) { this._id = undefined; throw "accessing a deleted edge"; } return shallowCopy(props); } //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- private methods // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup AvocadoGraph /// @{ //////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// /// @brief edge printing //////////////////////////////////////////////////////////////////////////////// Edge.prototype._PRINT = function (seen, path, names) { if (! this._id) { internal.output("[deleted Edge]"); } else if (this._eid !== undefined) { if (typeof this._eid === "string") { internal.output("Edge(\"", this._eid, "\")"); } else { internal.output("Edge(", this._eid, ")"); } } else { internal.output("Edge(\"", this._id, "\")"); } } //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- VERTEX // ----------------------------------------------------------------------------- // ----------------------------------------------------------------------------- // --SECTION-- constructors and destructors // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup AvocadoGraph /// @{ //////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// /// @brief constructs a new vertex object //////////////////////////////////////////////////////////////////////////////// function Vertex (graph, id) { var props; this._graph = graph; this._id = id; props = this._graph._vertices.document(this._id); // extract the custom identifier if (props) { this._vid = props.$vid; } // deleted else { this._id = undefined; } } //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- public functions // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup AvocadoGraph /// @{ //////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// /// @brief adds an inbound edge /// /// @FUN{@FA{vertex}.addInEdge(@FA{id}, @FA{peer})} /// /// Creates a new edge from @FA{peer} to @FA{vertex} and returns the edge /// object. The identifier @FA{id} must be a unique identifier or null. /// /// @FUN{@FA{vertex}.addInEdge(@FA{id}, @FA{peer}, @FA{label})} /// /// Creates a new edge from @FA{peer} to @FA{vertex} with given label and /// returns the edge object. /// /// @FUN{@FA{vertex}.addInEdge(@FA{id}, @FA{peer}, @FA{label}, @FA{data})} /// /// Creates a new edge from @FA{peer} to @FA{vertex} with given label and /// properties defined in @FA{data}. Returns the edge object. /// /// @EXAMPLES /// /// @verbinclude graph33 /// /// @verbinclude graph23 /// /// @verbinclude graph24 //////////////////////////////////////////////////////////////////////////////// Vertex.prototype.addInEdge = function (id, out, label, data) { if (! this._id) { throw "accessing a deleted vertex"; } return this._graph.addEdge(id, out, this, label, data); } //////////////////////////////////////////////////////////////////////////////// /// @brief adds an outbound edge /// /// @FUN{@FA{vertex}.addOutEdge(@FA{peer})} /// /// Creates a new edge from @FA{vertex} to @FA{peer} and returns the edge /// object. /// /// @FUN{@FA{vertex}.addOutEdge(@FA{peer}, @FA{label})} /// /// Creates a new edge from @FA{vertex} to @FA{peer} with given @FA{label} and /// returns the edge object. /// /// @FUN{@FA{vertex}.addOutEdge(@FA{peer}, @FA{label}, @FA{data})} /// /// Creates a new edge from @FA{vertex} to @FA{peer} with given @FA{label} and /// properties defined in @FA{data}. Returns the edge object. /// /// @EXAMPLES /// /// @verbinclude graph34 /// /// @verbinclude graph27 /// /// @verbinclude graph28 //////////////////////////////////////////////////////////////////////////////// Vertex.prototype.addOutEdge = function (id, ine, label, data) { if (! this._id) { throw "accessing a deleted vertex"; } return this._graph.addEdge(id, this, ine, label, data); } //////////////////////////////////////////////////////////////////////////////// /// @brief inbound and outbound edges /// /// @FUN{@FA{vertex}.edges()} /// /// Returns a list of in- or outbound edges of the @FA{vertex}. /// /// @EXAMPLES /// /// @verbinclude graph15 //////////////////////////////////////////////////////////////////////////////// Vertex.prototype.edges = function () { var query; var result; var graph; if (! this._id) { throw "accessing a deleted vertex"; } graph = this._graph; query = graph._edges.edges(this._id); result = []; for (var i = 0; i < query.length; ++i) { result.push(graph.constructEdge(query[i]._id)); } return result; } //////////////////////////////////////////////////////////////////////////////// /// @brief returns the identifier of a vertex /// /// @FUN{@FA{vertex}.getId()} /// /// Returns the identifier of the @FA{vertex}. If the vertex was deleted, then /// @CODE{undefined} is returned. /// /// @EXAMPLES /// /// @verbinclude graph8 //////////////////////////////////////////////////////////////////////////////// Vertex.prototype.getId = function (name) { return this._vid; } //////////////////////////////////////////////////////////////////////////////// /// @brief inbound edges with given label /// /// @FUN{@FA{vertex}.getInEdges(@FA{label}, ...)} /// /// Returns a list of inbound edges of the @FA{vertex} with given label(s). /// /// @EXAMPLES /// /// @verbinclude graph18 //////////////////////////////////////////////////////////////////////////////// Vertex.prototype.getInEdges = function () { var edges; var labels; var result; var edge; if (! this._id) { throw "accessing a deleted vertex"; } if (arguments.length == 0) { return this.inbound(); } else { labels = {}; for (var i = 0; i < arguments.length; ++i) { labels[arguments[i]] = true; } edges = this.inbound(); result = []; for (var i = 0; i < edges.length; ++i) { if (edges[i].getLabel() in labels) { result.push(edges[i]); } } return result; } } //////////////////////////////////////////////////////////////////////////////// /// @brief outbound edges with given label /// /// @FUN{@FA{vertex}.getOutEdges(@FA{label}, ...)} /// /// Returns a list of outbound edges of the @FA{vertex} with given label(s). /// /// @EXAMPLES /// /// @verbinclude graph19 //////////////////////////////////////////////////////////////////////////////// Vertex.prototype.getOutEdges = function () { var edges; var labels; var result; var edge; if (! this._id) { throw "accessing a deleted vertex"; } if (arguments.length == 0) { return this.outbound(); } else { labels = {}; for (var i = 0; i < arguments.length; ++i) { labels[arguments[i]] = true; } edges = this.outbound(); result = []; for (var i = 0; i < edges.length; ++i) { if (edges[i].getLabel() in labels) { result.push(edges[i]); } } return result; } } //////////////////////////////////////////////////////////////////////////////// /// @brief returns a property of a vertex /// /// @FUN{@FA{vertex}.getProperty(@FA{name})} /// /// Returns the property @FA{name} a @FA{vertex}. /// /// @EXAMPLES /// /// @verbinclude graph5 //////////////////////////////////////////////////////////////////////////////// Vertex.prototype.getProperty = function (name) { if (! this._id) { throw "accessing a deleted vertex"; } return this.properties()[name]; } //////////////////////////////////////////////////////////////////////////////// /// @brief gets all property names of a vertex /// /// @FUN{@FA{vertex}.getPropertyKeys()} /// /// Returns all propety names a @FA{vertex}. /// /// @EXAMPLES /// /// @verbinclude graph7 //////////////////////////////////////////////////////////////////////////////// Vertex.prototype.getPropertyKeys = function () { if (! this._id) { throw "accessing a deleted vertex"; } return propertyKeys(this.properties()); } //////////////////////////////////////////////////////////////////////////////// /// @brief inbound edges /// /// @FUN{@FA{vertex}.inbound()} /// /// Returns a list of inbound edges of the @FA{vertex}. /// /// @EXAMPLES /// /// @verbinclude graph16 //////////////////////////////////////////////////////////////////////////////// Vertex.prototype.inbound = function () { var query; var result; var graph; if (! this._id) { throw "accessing a deleted vertex"; } graph = this._graph; query = graph._edges.inEdges(this._id); result = []; for (var i = 0; i < query.length; ++i) { result.push(graph.constructEdge(query[i]._id)); } return result; } //////////////////////////////////////////////////////////////////////////////// /// @brief outbound edges /// /// @FUN{@FA{vertex}.outbound()} /// /// Returns a list of outbound edges of the @FA{vertex}. /// /// @EXAMPLES /// /// @verbinclude graph17 //////////////////////////////////////////////////////////////////////////////// Vertex.prototype.outbound = function () { var query; var result; var graph; if (! this._id) { throw "accessing a deleted vertex"; } graph = this._graph; query = graph._edges.outEdges(this._id); result = []; for (var i = 0; i < query.length; ++i) { result.push(graph.constructEdge(query[i]._id)); } return result; } //////////////////////////////////////////////////////////////////////////////// /// @brief returns all properties of a vertex /// /// @FUN{@FA{vertex}.properties()} /// /// Returns all properties and their values of a @FA{vertex} /// /// @EXAMPLES /// /// @verbinclude graph4 //////////////////////////////////////////////////////////////////////////////// Vertex.prototype.properties = function () { var props; var result; if (! this._id) { throw "accessing a deleted vertex"; } props = this._graph._vertices.document(this._id); if (! props) { this._id = undefined; throw "accessing a deleted vertex"; } return shallowCopy(props); } //////////////////////////////////////////////////////////////////////////////// /// @brief changes a property of a vertex /// /// @FUN{@FA{vertex}.setProperty(@FA{name}, @FA{value})} /// /// Changes or sets the property @FA{name} a @FA{vertex} to @FA{value}. /// /// @EXAMPLES /// /// @verbinclude graph6 //////////////////////////////////////////////////////////////////////////////// Vertex.prototype.setProperty = function (name, value) { var props; var shallow; if (! this._id) { throw "accessing a deleted vertex"; } delete this._properties; props = this._graph._vertices.document(this._id); // TODO use "update" if (props !== undefined) { shallow = shallowCopy(props); shallow[name] = value; this._graph._vertices.replace(this._id, shallow); return value; } else { return undefined; } } //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- private methods // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup AvocadoGraph /// @{ //////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// /// @brief vertex representation //////////////////////////////////////////////////////////////////////////////// Vertex.prototype._PRINT = function (seen, path, names) { if (! this._id) { internal.output("[deleted Vertex]"); } else if (this._vid !== undefined) { if (typeof this._vid === "string") { internal.output("Vertex(\"", this._vid, "\")"); } else { internal.output("Vertex(", this._vid, ")"); } } else { internal.output("Vertex(\"", this._id, "\")"); } } //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- GRAPH // ----------------------------------------------------------------------------- // ----------------------------------------------------------------------------- // --SECTION-- constructors and destructors // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup AvocadoGraph /// @{ //////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// /// @brief constructs a new graph object /// /// @FUN{Graph(@FA{vertices}, @FA{edges})} /// /// Constructs a new graph object using the collection @FA{vertices} for all /// vertices and the collection @FA{edges} for all edges. Note that it is /// possible to construct two graphs with the same vertex set, but different /// edge sets. /// /// @EXAMPLES /// /// @verbinclude graph1 //////////////////////////////////////////////////////////////////////////////// function Graph (vertices, edg) { if (typeof vertices === "string") { vertices = db[vertices]; vertices.ensureUniqueConstraint("$vid"); } if (! vertices instanceof AvocadoCollection) { throw " must be a document collection"; } if (typeof edg === "string") { edg = edges[edg]; edg.ensureUniqueConstraint("$eid"); } if (! edg instanceof AvocadoEdgesCollection) { throw " must be an edges collection"; } this._vertices = vertices; this._edges = edg; } //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- public functions // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup AvocadoGraph /// @{ //////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// /// @brief adds an edge to the graph /// /// @FUN{@FA{graph}.addEdge(@FA{id}, @FA{out}, @FA{in})} /// /// Creates a new edge from @FA{out} to @FA{in} and returns the edge object. The /// identifier @FA{id} must be a unique identifier or null. /// /// @FUN{@FA{graph}.addEdge(@FA{id}, @FA{out}, @FA{in}, @FA{label})} /// /// Creates a new edge from @FA{out} to @FA{in} with @FA{label} and returns the /// edge object. /// /// @FUN{@FA{graph}.addEdge(@FA{id}, @FA{out}, @FA{in}, @FA{data})} /// /// Creates a new edge and returns the edge object. The edge contains the /// properties defined in @FA{data}. /// /// @FUN{@FA{graph}.addEdge(@FA{id}, @FA{out}, @FA{in}, @FA{label}, @FA{data})} /// /// Creates a new edge and returns the edge object. The edge has the /// label @FA{label} and contains the properties defined in @FA{data}. /// /// @EXAMPLES /// /// @verbinclude graph30 /// /// @verbinclude graph9 /// /// @verbinclude graph31 /// /// @verbinclude graph10 //////////////////////////////////////////////////////////////////////////////// Graph.prototype.addEdge = function (id, out, ine, label, data) { var ref; var shallow; var key; var edge; if (typeof label === 'object') { data = label; label = undefined; } if (label === undefined) { label = null; } if (data == null || typeof data !== "object") { data = {}; } shallow = shallowCopy(data); shallow.$eid = id || null; shallow.$label = label || null; ref = this._edges.save(out._id, ine._id, shallow); return this.constructEdge(ref); } //////////////////////////////////////////////////////////////////////////////// /// @brief adds a vertex to the graph /// /// @FUN{@FA{graph}.addVertex(@FA{id})} /// /// Creates a new vertex and returns the vertex object. The identifier /// @FA{id} must be a unique identifier or null. /// /// @FUN{@FA{graph}.addVertex(@FA{id}, @FA{data})} /// /// Creates a new vertex and returns the vertex object. The vertex contains /// the properties defined in @FA{data}. /// /// @EXAMPLES /// /// Without any properties: /// /// @verbinclude graph2 /// /// With given properties: /// /// @verbinclude graph3 //////////////////////////////////////////////////////////////////////////////// Graph.prototype.addVertex = function (id, data) { var ref; var shallow; if (data == null || typeof data !== "object") { data = {}; } shallow = shallowCopy(data); shallow.$vid = id || null; ref = this._vertices.save(shallow); return this.constructVertex(ref); } //////////////////////////////////////////////////////////////////////////////// /// @brief returns a vertex given its id /// /// @FUN{@FA{graph}.getVertex(@FA{id})} /// /// Returns the vertex identified by @FA{id} or undefined. /// /// @EXAMPLES /// /// @verbinclude graph29 //////////////////////////////////////////////////////////////////////////////// Graph.prototype.getVertex = function (id) { var ref; ref = this._vertices.select({ $vid : id }); if (ref.count() == 1) { return this.constructVertex(ref.next()._id); } else { return undefined; } } //////////////////////////////////////////////////////////////////////////////// /// @brief returns an iterator for all vertices /// /// @FUN{@FA{graph}.getVertices()} /// /// Returns an iterator for all vertices of the graph. The iterator supports the /// methods @FN{hasNext} and @FN{next}. /// /// @EXAMPLES /// /// @verbinclude graph35 //////////////////////////////////////////////////////////////////////////////// Graph.prototype.getVertices = function () { var that; var all; that = this; all = this._vertices.all(); iterator = function() { this.next = function next() { var v; v = all.next(); if (v == undefined) { return undefined; } return that.constructVertex(v._id); }; this.hasNext = function hasNext() { return all.hasNext(); }; this._PRINT = function(seen, path, names) { internal.output("[vertex iterator]"); } }; return new iterator(); } //////////////////////////////////////////////////////////////////////////////// /// @brief returns an iterator for all edges /// /// @FUN{@FA{graph}.getEdges()} /// /// Returns an iterator for all edges of the graph. The iterator supports the /// methods @FN{hasNext} and @FN{next}. /// /// @EXAMPLES /// /// @verbinclude graph36 //////////////////////////////////////////////////////////////////////////////// Graph.prototype.getEdges = function () { var that; var all; that = this; all = this._edges.all(); iterator = function() { this.next = function next() { var v; v = all.next(); if (v == undefined) { return undefined; } return that.constructEdge(v._id); }; this.hasNext = function hasNext() { return all.hasNext(); }; this._PRINT = function(seen, path, names) { internal.output("[edge iterator]"); } }; return new iterator(); } //////////////////////////////////////////////////////////////////////////////// /// @brief removes a vertex and all in- or out-bound edges /// /// @FUN{@FA{graph}.removeVertex(@FA{vertex})} /// /// Deletes the @FA{vertex} and all its edges. /// /// @EXAMPLES /// /// @verbinclude graph37 //////////////////////////////////////////////////////////////////////////////// Graph.prototype.removeVertex = function (vertex) { var result; if (! vertex._id) { return; } edges = vertex.edges(); result = this._vertices.delete(vertex._id); if (! result) { throw "cannot delete vertex"; } vertex._id = undefined; for (var i = 0; i < edges.length; ++i) { this.removeEdge(edges[i]); } } //////////////////////////////////////////////////////////////////////////////// /// @brief removes an edge /// /// @FUN{@FA{graph}.removeEdge(@FA{vertex})} /// /// Deletes the @FA{edge}. Note that the in and out vertices are left untouched. /// /// @EXAMPLES /// /// @verbinclude graph38 //////////////////////////////////////////////////////////////////////////////// Graph.prototype.removeEdge = function (edge) { var result; if (! edge._id) { return; } result = this._edges.delete(edge._id); if (! result) { throw "cannot delete edge"; } edge._id = undefined; } //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- private functions // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup AvocadoGraph /// @{ //////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// /// @brief private function to construct a vertex //////////////////////////////////////////////////////////////////////////////// Graph.prototype.constructVertex = function(id) { return new Vertex(this, id); } //////////////////////////////////////////////////////////////////////////////// /// @brief private function to construct an edge //////////////////////////////////////////////////////////////////////////////// Graph.prototype.constructEdge = function(id) { return new Edge(this, id); } //////////////////////////////////////////////////////////////////////////////// /// @brief graph printing //////////////////////////////////////////////////////////////////////////////// Graph.prototype._PRINT = function (seen, path, names) { internal.output("Graph(\"", this._vertices.name(), "\", \"" + this._edges.name(), "\")"); } //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- private methods // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup AvocadoGraph /// @{ //////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// /// @brief shallow copy properties //////////////////////////////////////////////////////////////////////////////// function shallowCopy (props) { var shallow; shallow = {}; for (var key in props) { if (props.hasOwnProperty(key) && key[0] != '_' && key[0] != '$') { shallow[key] = props[key]; } } return shallow; } //////////////////////////////////////////////////////////////////////////////// /// @brief property keys //////////////////////////////////////////////////////////////////////////////// function propertyKeys (props) { var keys; keys = []; for (var key in props) { if (props.hasOwnProperty(key) && key[0] != '_' && key[0] != '$') { keys.push(key); } } return keys; } //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- MODULE EXPORTS // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup AvocadoGraph /// @{ //////////////////////////////////////////////////////////////////////////////// exports.AvocadoCollection = AvocadoCollection; exports.AvocadoEdgesCollection = AvocadoEdgesCollection; exports.Edge = Edge; exports.Graph = Graph; exports.Vertex = Vertex; //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // Local Variables: // mode: outline-minor // outline-regexp: "^\\(/// @brief\\|/// @addtogroup\\|// --SECTION--\\|/// @page\\|/// @}\\)" // End: