Files
harbour-core/harbour/tests/objarr.prg
Viktor Szakats 175f05df56 2013-02-26 14:41 UTC+0100 Viktor Szakats (harbour syenar.net)
* utils/hbmk2/hbmk2.*.po
  * utils/hbmk2/hbmk2.prg
    + do not share plugin variables (hbmk[ "vars" ])
      between different plugins. It avoids potentially nasty
      issues with plugins stepping onto each other's toes.
      [INCOMPATIBLE - though it's unlikely anyone is
      affected. If you must communicate between plugins,
      use public function or variable.]
    + clarified in help that -icon might not work on all
      platforms/compilers and detailed Windows implementation
      (in particular it's disabled on bcc/bcc64 and on
      mingw it won't work when a manual .rc is specified,
      also on some (old?) msvc versions. Consult your
      C compiler's Windows resource handling limitations.)
    + clarified in help the syntax of filters
    + clarified in help that .hbp references are handled as
      sub-projects
    + clarification to command substitution macro
    + clarification to filter syntax note
    ! strict parameter checks in all public shell APIs to
      avoid RTEs inside hbmk2 due to faulty API usage by scripts

  * utils/hbmk2/examples/plug_bis.hb
    * updated according to latest plugin changes

  * include/harbour.hbx
  * include/hbapi.h
  * src/vm/debug.c
  * src/vm/hvm.c
    + added internal function hb_vmInternalsEnabled()
      to query whether potentially sensitive internals
      are allowed to be accessed by public Harbour APIs
    + added .prg level function __vmNoInternals()
      to disable potentially sensitive internals
      by default accessible via public APIs.
      Intentionally a one-way function: once disabled,
      it cannot be reenabled from .prg or .c level.
      NOTE: It will break Harbour debug functionality,
      so it'd will be useful for hbrun scripts and
      release (non-debug) builds.
    + modified internal __dbg*() functions to return
      dummy values when internals are disabled via
      __vmNoInternals() functions. While the function
      return types are kept, apps relying on their
      specific values and certain relationships between
      them might break.
    ; NOTE: In the future, some more internals might
      be protected by this setting (f.e. low-level
      object and class functions and some API from
      hbdebug lib)
    ; Please review

  * tests/debugtst.prg
    ! fixed to compile warning-free without lowering
      warning level
    ! fixed to run RTE-free with internals disabled

  * bin/3rdpatch.hb
  * bin/commit.hb
  * config/postinst.hb
  * contrib/make.hb
  * contrib/hbtest/hbtest.ch
  * src/debug/*.prg
  * src/rtl/tclass.prg
  * utils/hbmk2/examples/plug_bis.hb
  * utils/hbmk2/examples/plug_tpl.hb
    * use short form #pragmas (the ones identical
      to Harbour options)
    ; NOTE: Except -l which works reversed compared
      to cmdline -l option. TOFIX? (I tried and failed)

  * src/rtl/hbi18n2.prg
  * contrib/xhb/tfile.prg
    * use F_ERROR instead of -1 literal

  * contrib/xhb/xhbtedit.prg
    ! replaced dirty xhb extension with std SubStr() call
      Reported by Tony Quick
      [pls report such bugs on Harbour devl list]

  * contrib/hbodbc/todbc.prg
    ! Don't continue ::Open() when SQLExecDir() have error
      Fix from xhb via Vicente Guerra, with cleanups.

  * tests/multifnc/multifnc.hbp
    + added comment
    + support for watcom

  * tests/multifnc/t1.prg
    ! missing file ending EOL

  * tests/*.prg
  * extras/gtwvw/tests/wvwtest9.prg
    * formatting
2013-02-26 13:44:10 +00:00

92 lines
1.8 KiB
Plaintext

/*
* $Id$
*/
//
// Object Array syntax test
//
// Written by Eddie Runia <eddie@runia.com>
// www - http://harbour-project.org
//
// Placed in the public domain
//
PROCEDURE Main()
LOCAL o := TNumber():New()
? "Direct reference : ", hb_ValToStr( o:x )
o:x[ 1 ] := "I am a data"
o:Get()[ 2 ] := "I am a method"
? "Assign text : ", hb_ValToStr( o:x )
o:x[ 1 ] := 4
o:Get()[ 2 ] := 4
? "Assign 4 : ", hb_ValToStr( o:x )
? "Post increment : ", o:x[ 1 ]++ , o:Get()[ 2 ]++
? "After : ", o:x[ 1 ] , o:Get()[ 2 ]
? "Pre decrement : ", --o:x[ 1 ] , --o:Get()[ 2 ]
? "After : ", o:x[ 1 ] , o:Get()[ 2 ]
o:x[ 1 ] += 2
o:Get()[ 2 ] += 2
? "Plus 2 : ", hb_ValToStr( o:x )
o:x[ 1 ] -= 3
o:Get()[ 2 ] -= 3
? "Minus 3 : ", hb_ValToStr( o:x )
o:x[ 1 ] *= 3
o:Get()[ 2 ] *= 3
? "Times 3 : ", hb_ValToStr( o:x )
o:x[ 1 ] /= 1.5
o:Get()[ 2 ] /= 1.5
? "Divide by 1.5 : ", hb_ValToStr( o:x )
o:x[ 1 ] %= 4
o:Get()[ 2 ] %= 4
? "Modulus 4 : ", hb_ValToStr( o:x )
o:x[ 1 ] ^= 3
o:Get()[ 2 ] ^= 3
? "To the power 3 : ", hb_ValToStr( o:x )
? "Global stack"
? hb_ValToExp( __dbgVMStkGList() )
? "Statics"
? hb_ValToExp( __dbgVMVarSList() )
RETURN
FUNCTION TNumber() // Very simple class
STATIC oNumber
IF oNumber == NIL
oNumber := HBClass():New( "TNumber" )
oNumber:AddData ( "x" )
oNumber:AddMethod( "Get", @Get() )
oNumber:AddMethod( "New", @New() )
oNumber:Create()
ENDIF
RETURN oNumber:Instance()
STATIC FUNCTION New()
LOCAL self := QSelf()
::x := { 1, 1 }
RETURN self
STATIC FUNCTION Get()
LOCAL self := QSelf()
RETURN ::x