1 #=====================================================================
 
   4 # Based on SQL-Ledger Version 2.1.9
 
   5 # Web http://www.lx-office.org
 
   7 #=====================================================================
 
   8 # SQL-Ledger Accounting
 
  11 #  Author: Dieter Simader
 
  12 #   Email: dsimader@sql-ledger.org
 
  13 #     Web: http://www.sql-ledger.org
 
  17 # This program is free software; you can redistribute it and/or modify
 
  18 # it under the terms of the GNU General Public License as published by
 
  19 # the Free Software Foundation; either version 2 of the License, or
 
  20 # (at your option) any later version.
 
  22 # This program is distributed in the hope that it will be useful,
 
  23 # but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  24 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  25 # GNU General Public License for more details.
 
  26 # You should have received a copy of the GNU General Public License
 
  27 # along with this program; if not, write to the Free Software
 
  28 # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
  29 #=====================================================================
 
  31 # routines to retrieve / manipulate win ini style files
 
  32 # ORDER is used to keep the elements in the order they appear in .ini
 
  34 #=====================================================================
 
  39   $main::lxdebug->enter_sub();
 
  41   my ($type, $file, $level) = @_;
 
  48   $type = ref($self) || $self;
 
  50   open FH, "$file" or Form->error("$file : $!");
 
  61     # remove any trailing whitespace
 
  69       # if there is a level skip
 
  70       if ($skip = ($id !~ /^$level/)) {
 
  74       push @{ $self->{ORDER} }, $_;
 
  82       # add key=value to $id
 
  83       my ($key, $value) = split /=/, $_, 2;
 
  85       $self->{$id}{$key} = $value;
 
  91   $main::lxdebug->leave_sub();