SOL9 2.0 Class: ObjectArray

 SOL9 C++ Class Library  SOL9 Samples  SOL9 Tutorial  SOL9 FAQ  SOL9 ClassTree  SOL9 ClassList 

Source code

/******************************************************************************
 *
 * Copyright (c) 1999-2008 Antillia.com TOSHIYUKI ARAI. ALL RIGHTS RESERVED.
 *
 * 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. 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.
 *
 *
 *  ObjectArray.h
 *
 *****************************************************************************/

// SOL++2000
#pragma once

#include <sol\Array.h> 

namespace SOL {

class ObjectArray :public Array {
private:
  Object** array;

public:
  ObjectArray(UINT size)
    :Array(size) 
  {
    array = new Object*[size];
    for(UINT i = 0; i<size; i++) {
      array[i] = NULL;
    }
  }

public:
  ~ObjectArray() 
  {
    delete [] array;
  }


public:
  BOOL set(UINT n, Object* object)
  {
    BOOL rc = FALSE;
    if(n <getSize()) {
      array[n] = object;  
      rc = TRUE;
    }
    return rc;
  }

public:
  Object* get(UINT n) 
  {
    Object* object = NULL;
    if(n < getSize()) {
      object = array[n];
    }
    return object;
  }

public:
  void sort(SortDirection dir)
  {
    int length = getSize();

    for (int i = 0; i<length -1; i++) {
      int j = i+1;
      Object*  obj = array[i];
      int  c = 0;
      for(j = i+1; j<length; j++) {
        Object* jthObj = array[j];
        if (dir == ASCENDING) {
          if (jthObj -> compare(obj) > 0) {
            c = j;
            obj = array[j];
          }  
        }
        if (dir == DESCENDING) {
          if (jthObj -> compare(obj) < 0) {
            c = j;
            obj = array[j];
          }  
        }
      }

      array[c] = array[i];
      array[i] = obj;
    }  
  }


};

}


Last modified: 5 May 2019

Copyright (c) 2009-2019 Antillia.com ALL RIGHTS RESERVED.