;;; jupiter-compound.el --- Jupiter compound operation -*- lexical-binding:t -*- ;; ;; Copyright (C) 2009, 2014, 2016 Free Software Foundation, Inc. ;; ;; Author: Jan Moringen ;; Keywords: jupiter, operation, compound ;; X-RCS: $Id:$ ;; ;; This file is part of Rudel. ;; ;; Rudel is free software: you can redistribute it and/or modify it ;; under the terms of the GNU General Public License as published by ;; the Free Software Foundation, either version 3 of the License, or ;; (at your option) any later version. ;; ;; Rudel is distributed in the hope that it will be useful, but ;; WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ;; General Public License for more details. ;; ;; You should have received a copy of the GNU General Public License ;; along with Rudel. If not, see . ;;; Commentary: ;; ;; Class `jupiter-compound' implements a compound operation comprised ;; of a number of child operations. ;;; History: ;; ;; 0.1 - Initial revision ;;; Code: ;; (require 'eieio) (require 'jupiter-operation) ;;; Class jupiter-compound ;; (defclass jupiter-compound (jupiter-operation) ((children :initarg :children :type list :initform nil :documentation "")) "Objects of this class are operations, which are composed of a number of child operation.") ;; TODO this has side effects. It can only be called once (cl-defmethod rudel-apply ((this jupiter-compound) object) "Apply THIS to BUFFER by applying the child operation." (with-slots (children) this (let ((child (car children)) (rest (cdr children))) ;; Apply all child operations (while child (rudel-apply child object) ;; For each applied child operation, transform remaining ;; operation with the applied operation. (dolist (next rest) (setf next (jupiter-transform child next))) ;; Advance to next child operation. (setq child (pop rest))))) ) (cl-defmethod jupiter-transform ((this jupiter-compound) other) "Transform OTHER using the child operations of THIS." (with-slots (children) this (dolist (child children) ;; TODO reverse children? (setq other (jupiter-transform child other))) other)) (cl-defmethod object-print ((this jupiter-compound) &rest _strings) "Add number of children to string representation of THIS." (with-slots (children) this (cl-call-next-method this (format " children %d" (length children))))) (provide 'jupiter-compound) ;;; jupiter-compound.el ends here