/* Menes - C++ High-Level Utility Library * Copyright (C) 2005 Jay Freeman (saurik) */ /* * Redistribution and use in source and binary * forms, with or without modification, are permitted * provided that the following conditions are met: * * 1. Redistributions of source code must retain the * above copyright notice, this list of conditions * and the following disclaimer. * 2. 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. * 3. The name of the author may not be used to endorse * or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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. */ namespace { typedef A: struct; typedef bob: ^(const int) A; auto x(0): const int; function main: (argc: int, argv: []^char) int { auto x(0): int; return x; } template <[a: typename]> typedef Object: class { } typedef Word: enum { pronoun = 0; noun; verb; } template <[a: typename, b = ext::RedBlackMap<[a, int]>: typename]> typedef Vector: class : public Object<[a]> { public: auto base: ^int; /* this is a comment */ function ~constructor: (base2: ^int). : base(base2) // comment { } private const: function getBase: () ^int { /*while (auto (NULL): ^int) { }*/ /*while (c(this); getBase(); base = c = true); if (base[5]^.works() ? 0 : 1 ? 9 : 10);*/ if (0) { } else if (10) { } else { } if (0) if (0) { } else { } return base; } } }