/** * Wrapper permitting the definition of abstract classes * * This doesn't actually introduce any new functionality. Rather, it sets a flag * to allow abstract methods within a class, forcing users to clearly state * that a class is abstract. * * Copyright (C) 2010 Mike Gerwitz * * This file is part of ease.js. * * ease.js is free software: you can redistribute it and/or modify it under the * terms of the GNU Lesser General Public License as published by the Free * Software Foundation, either version 3 of the License, or (at your option) * any later version. * * This program 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 Lesser General Public License * for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program. If not, see . * * @author Mike Gerwitz * @package core */ var Class = require( __dirname + '/class' ); /** * Creates an abstract class * * @return {Class} abstract class */ module.exports = exports = function() { markAbstract( arguments ); // forward everything to Class return Class.apply( this, arguments ); }; /** * Creates an abstract class from a class extend operation * * @return {Class} abstract class */ exports.extend = function() { markAbstract( arguments ); return Class.extend.apply( this, arguments ); }; /** * Creates an abstract class implementing the given members * * Simply wraps the class module's implement() method. * * @return {Object} abstract class */ exports.implement = function() { var impl = Class.implement.apply( this, arguments ), extend = impl.extend; // wrap extend, applying the abstract flag impl.extend = function() { markAbstract( arguments ); return extend.apply( this, arguments ); }; return impl; }; /** * Causes a definition to be flagged as abstract * * This function assumes the last argument to be the definition, which is the * common case, and modifies the object referenced by that argument. * * @param {arguments} args arguments to parse * * @return {undefined} */ function markAbstract( args ) { // the last argument _should_ be the definition var dfn = args[ args.length - 1 ]; if ( typeof dfn === 'object' ) { // mark as abstract dfn.___$$abstract$$ = true; } }