diff options
author | John Wiegley <johnw@newartisans.com> | 2010-06-13 00:42:25 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2010-06-13 00:42:25 -0400 |
commit | 40f553228f5a28034c6635fdcb4c86af28a385ed (patch) | |
tree | 2c40305c9f9841a4c3d453a4a5c49ec69056b4b2 | |
parent | 556211e623cad88213e5087b5c9c36e754d9aa02 (diff) | |
parent | b1b4e2aadff5983d443d70c09ea86a41b015873f (diff) | |
download | fork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.tar.gz fork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.tar.bz2 fork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.zip |
Merge branch 'next'
148 files changed, 7507 insertions, 7269 deletions
@@ -13,7 +13,7 @@ and it will keep you updated to the very latest version. =============================================================================== - NOTE FOR MAC OS X USERS + NOTE FOR MAC OS X USERS To build and install Ledger on the Mac requires several dependencies. If you are a MacPorts user, you can install these dependencies very simply using: @@ -33,7 +33,7 @@ available for testing and more useful bug reports. =============================================================================== - IF YOU HAVE CONFIGURE OR BUILD PROBLEMS + IF YOU HAVE CONFIGURE OR BUILD PROBLEMS The first order of business if acprep update doesn't work is to find out where things went wrong. So follow these steps to produce a bug report I can track diff --git a/README.textile b/README.textile index 2a730746..2d36c20a 100644 --- a/README.textile +++ b/README.textile @@ -105,10 +105,10 @@ If you're going to be build on Ubuntu, @sudo apt-get install ...@ the following packages (current as of Ubuntu Hardy): <pre> -sudo apt-get install build-essential libtool autoconf automake \ +sudo apt-get install build-essential libtool autoconf automake \ zlib1g-dev libbz2-dev python-dev bjam cvs gettext libgmp3-dev \ - libmpfr-dev libboost1.35-dev libboost-regex1.35-dev \ - libboost-date-time1.35-dev libboost-filesystem1.35-dev \ + libmpfr-dev libboost1.35-dev libboost-regex1.35-dev \ + libboost-date-time1.35-dev libboost-filesystem1.35-dev \ libboost-python1.35-dev texinfo lcov sloccount </pre> @@ -44,6 +44,7 @@ search_prefixes = [ '/opt/local', class BoostInfo(object): log = None suffix = "" + file_suffix = ".so" home_path = "/usr" include_path = "include" library_path = "lib" @@ -52,13 +53,14 @@ class BoostInfo(object): def __init__(self, log): self.log = log - def configure(self, suffix = None, home_path = None, + def configure(self, suffix = None, file_suffix = None, home_path = None, include_path = None, library_path = None): path = library_path or self.library_path if not isabs(path): path = join(home_path or self.home_path, path) if not exists(path) or not isdir(path) or \ - not self.check_for_boost_regex_lib(path, suffix or self.suffix): + not self.check_for_boost_regex_lib(path, suffix or self.suffix, + file_suffix or self.file_suffix): return False path = include_path or self.include_path @@ -72,6 +74,9 @@ class BoostInfo(object): if suffix: self.log.debug('Setting Boost suffix to => ' + suffix) self.suffix = suffix + if file_suffix: + self.log.debug('Setting Boost file suffix to => ' + file_suffix) + self.file_suffix = file_suffix if home_path: self.log.debug('Setting Boost home to => ' + home_path) self.home_path = home_path @@ -90,6 +95,10 @@ class BoostInfo(object): self.log.debug('Saw option --boost or --boost-suffix') self.suffix = value + def option_boost_file_suffix(self, option=None, opt_str=None, value=None, parser=None): + self.log.debug('Saw option --boost-file-suffix') + self.file_suffix = value + def option_boost_home(self, option=None, opt_str=None, value=None, parser=None): self.log.debug('Saw option --boost-home') self.home_path = value @@ -104,21 +113,25 @@ class BoostInfo(object): def inform_boost_details(self): self.log.info('Boost was found here:') + self.log.info('Boost home path => ' + self.home_path) self.log.info('Boost include path => ' + self.include_directory()) self.log.info('Boost library path => ' + self.library_directory()) - self.log.info('Boost suffix => ' + self.suffix) + self.log.info('Boost suffix => ' + self.suffix) + self.log.info('Boost file suffix => ' + self.file_suffix) def find_boost_in_directory(self, path): if exists(path) and isdir(path): for entry in reversed(sorted(os.listdir(path))): if re.search('boost_regex', entry): - self.log.info('Found a Boost library: ' + entry) + self.log.info('Found a Boost library: ' + join(path, entry)) - match = re.match('libboost_regex([^.]*)\.(a|so|dylib)', entry) + match = re.match('libboost_regex([^.]*)(\.(a|so|dylib))', entry) if match: suffix = match.group(1) + file_suffix = match.group(2) self.log.info('Found a Boost suffix => ' + suffix) - return suffix + self.log.info('Found a Boost file suffix => ' + file_suffix) + return [suffix, file_suffix] else: self.log.debug('The directory "%s" is not valid, skipping' % path) return None @@ -126,22 +139,24 @@ class BoostInfo(object): def locate_boost(self): lib64_dirs = map(lambda x: join(x, 'lib64'), search_prefixes) lib_dirs = map(lambda x: join(x, 'lib'), search_prefixes) + result = None for path in lib64_dirs + lib_dirs: self.log.info('Looking for Boost in %s...' % path) - self.suffix = self.find_boost_in_directory(path) - if self.suffix is not None: + result = self.find_boost_in_directory(path) + if result is not None: + self.suffix, self.file_suffix = result + self.library_path = path self.home_path = dirname(path) self.configured = True self.inform_boost_details() break - if self.suffix is None: - self.log.error("Boost not found, try --boost-home (and --boost-suffix)") + if result is None: + self.log.error("Boost not found, try --boost-home (and --boost-suffix, --boost-file-suffix)") sys.exit(1) - def check_for_boost_regex_lib(self, path, suffix): + def check_for_boost_regex_lib(self, path, suffix, file_suffix): regex_lib = join(path, 'libboost_regex' + suffix) - return (exists(regex_lib + '.a') or exists(regex_lib + '.lib') or - exists(regex_lib + '.so') or exists(regex_lib + '.dylib')) + return exists(regex_lib + file_suffix) def check_for_boost_regex_hpp(self, path): regex_hpp = join(path, 'boost/regex.hpp') @@ -152,6 +167,11 @@ class BoostInfo(object): self.locate_boost() return self.suffix + def get_file_suffix(self): + if not self.configured: + self.locate_boost() + return self.file_suffix + def include_directory(self): if not self.configured: self.locate_boost() @@ -184,7 +204,7 @@ class BoostInfo(object): self.log.error("Boost library directory '%s' not found, use --boost-include" % path) sys.exit(1) - if not self.check_for_boost_regex_lib(path, self.suffix): + if not self.check_for_boost_regex_lib(path, self.suffix, self.file_suffix): self.log.error("Could not find Boost library 'boost_regex' in '%s'; use --boost-* flags" % path) sys.exit(1) @@ -218,7 +238,6 @@ class CommandLineApp(object): log_handler = None darwin_gcc = False boost_version = "1_43" - gcc_version = "45" options = { 'debug': False, @@ -414,10 +433,14 @@ class PrepareBuild(CommandLineApp): action="callback", type="string", callback=self.boost_info.option_boost_suffix, help='Set Boost library suffix (ex: "--boost=-mt")') - op.add_option('', '--boost-sufix', metavar='BOOST_SUFFIX', + op.add_option('', '--boost-suffix', metavar='BOOST_SUFFIX', action="callback", type="string", callback=self.boost_info.option_boost_suffix, help='Set Boost library suffix (ex: "--boost-suffix=-mt")') + op.add_option('', '--boost-file-suffix', metavar='BOOST_FILE_SUFFIX', + action="callback", type="string", + callback=self.boost_info.option_boost_file_suffix, + help='Set Boost library file suffix (ex: "--boost-file-suffix=.so")') op.add_option('', '--boost-home', metavar='BOOST_HOME', action="callback", type="string", callback=self.boost_info.option_boost_home, @@ -458,6 +481,12 @@ class PrepareBuild(CommandLineApp): op.add_option('', '--no-python', action='store_true', dest='no_python', default=False, help='Do not enable Python support by default') + op.add_option('', '--enable-cache', action='store_true', + dest='enable_cache', default=False, + help='Enable use of Boost.Serialization (--cache)') + op.add_option('', '--enable-doxygen', action='store_true', + dest='enable_doxygen', default=False, + help='Enable use of Doxygen to build ref manual ("make docs")') op.add_option('', '--universal', action='store_true', dest='universal', default=False, help='Attempt to build universal binaries') @@ -617,7 +646,7 @@ class PrepareBuild(CommandLineApp): self.should_clean = True return 'because acprep is newer than Makefile.in' elif self.isnewer('configure.ac', 'configure'): - return 'because confgure.ac is newer than configure' + return 'because configure.ac is newer than configure' elif self.isnewer('Makefile.am', 'Makefile.in'): return 'because Makefile.am is newer than Makefile.in' return False @@ -661,7 +690,7 @@ class PrepareBuild(CommandLineApp): def phase_sloc(self, *args): self.log.info('Executing phase: sloc') - self.execute('sloccount', 'src', 'python', 'lisp', 'test') + self.execute('sloccount', 'src', 'python', 'lisp', 'test') ######################################################################### # Configure source tree using autogen # @@ -885,9 +914,16 @@ class PrepareBuild(CommandLineApp): ######################################################################### def setup_system_directories(self): + boost_include = self.boost_info.include_directory() + boost_library = self.boost_info.library_directory() + + if re.match('/opt/local', self.boost_info.home_path): + self.log.debug("Setting Python home to /opt/local based on Boost's location") + self.envvars['PYTHON_HOME'] = '/opt/local' + # Each of these becomes '-isystem <name>' for path in ['/usr/local/include', - self.boost_info.include_directory(), + boost_include, '%s/include/python%s' % (self.envvars['PYTHON_HOME'], self.envvars['PYTHON_VERSION'].strip()), @@ -905,7 +941,7 @@ class PrepareBuild(CommandLineApp): % (self.envvars['PYTHON_HOME'], self.envvars['PYTHON_VERSION'].strip()), '/opt/local/lib', - self.boost_info.library_directory(), + boost_library, '/sw/lib']: if exists(path) and isdir(path) and \ path not in self.sys_library_dirs: @@ -913,18 +949,24 @@ class PrepareBuild(CommandLineApp): self.sys_library_dirs.append(path) def setup_for_johnw(self): + match = re.search('gcc-mp-([0-9]+)\.([0-9]+)', self.envvars['CC']) + if match: + gcc_version = match.group(1) + match.group(2) + else: + gcc_version = "42" + if self.current_flavor == 'debug' or self.current_flavor == 'gcov': - if exists('/usr/local/stow/cppunit-gcc%s/include' % self.gcc_version): + if exists('/usr/local/stow/cppunit-gcc%s/include' % gcc_version): self.sys_include_dirs.insert( - 0, '/usr/local/stow/cppunit-gcc%s/include' % self.gcc_version) + 0, '/usr/local/stow/cppunit-gcc%s/include' % gcc_version) self.sys_library_dirs.insert( - 0, '/usr/local/stow/cppunit-gcc%s/lib' % self.gcc_version) + 0, '/usr/local/stow/cppunit-gcc%s/lib' % gcc_version) - if exists('/usr/local/stow/icu-gcc%s/include' % self.gcc_version): + if exists('/usr/local/stow/icu-gcc%s/include' % gcc_version): self.sys_include_dirs.insert( - 0, '/usr/local/stow/icu-gcc%s/include' % self.gcc_version) + 0, '/usr/local/stow/icu-gcc%s/include' % gcc_version) self.sys_library_dirs.insert( - 0, '/usr/local/stow/icu-gcc%s/lib' % self.gcc_version) + 0, '/usr/local/stow/icu-gcc%s/lib' % gcc_version) self.CPPFLAGS.append('-D_GLIBCXX_FULLY_DYNAMIC_STRING=1') self.configure_args.append('--disable-shared') @@ -937,10 +979,6 @@ class PrepareBuild(CommandLineApp): self.locate_darwin_libraries() def setup_for_system(self): - if exists('/Users/johnw/Projects/ledger/plan/TODO'): - self.setup_for_johnw() - self.setup_system_directories() - system = self.get_stdout('uname', '-s') self.log.info('System type is => ' + system) @@ -991,6 +1029,15 @@ class PrepareBuild(CommandLineApp): # g++ 4.0.1 cannot use PCH headers on OS X 10.5 self.option_no_pch() + if self.options.enable_doxygen: + self.configure_args.append('--enable-doxygen') + if self.options.enable_cache: + self.configure_args.append('--enable-cache') + + if exists('/Users/johnw/Projects/ledger/plan/TODO'): + self.setup_for_johnw() + self.setup_system_directories() + if '--enable-pch' not in self.configure_args and \ (exists('/opt/local/bin/ccache') or \ exists('/usr/local/bin/ccache')): @@ -1087,30 +1134,30 @@ class PrepareBuild(CommandLineApp): def option_warn(self, option=None, opt_str=None, value=None, parser=None): self.log.debug('Saw option --warn') - self.CXXFLAGS.append('-ansi') - self.CXXFLAGS.append('-pedantic') - self.CXXFLAGS.append('-pedantic-errors') - self.CXXFLAGS.append('-Wall') - self.CXXFLAGS.append('-Winvalid-pch') - self.CXXFLAGS.append('-Wextra') - self.CXXFLAGS.append('-Wcast-align') - self.CXXFLAGS.append('-Wcast-qual') - self.CXXFLAGS.append('-Wfloat-equal') - self.CXXFLAGS.append('-Wmissing-field-initializers') - self.CXXFLAGS.append('-Wno-endif-labels') - self.CXXFLAGS.append('-Woverloaded-virtual') - self.CXXFLAGS.append('-Wsign-compare') - self.CXXFLAGS.append('-Wsign-promo') - self.CXXFLAGS.append('-Wstrict-null-sentinel') - self.CXXFLAGS.append('-Wwrite-strings') - self.CXXFLAGS.append('-Wno-old-style-cast') - self.CXXFLAGS.append('-Wno-deprecated') - self.CXXFLAGS.append('-Wno-strict-aliasing') - self.CXXFLAGS.append('-Werror') + self.CXXFLAGS.append('-ansi') + self.CXXFLAGS.append('-pedantic') + self.CXXFLAGS.append('-pedantic-errors') + self.CXXFLAGS.append('-Wall') + self.CXXFLAGS.append('-Winvalid-pch') + self.CXXFLAGS.append('-Wextra') + self.CXXFLAGS.append('-Wcast-align') + self.CXXFLAGS.append('-Wcast-qual') + self.CXXFLAGS.append('-Wfloat-equal') + self.CXXFLAGS.append('-Wmissing-field-initializers') + self.CXXFLAGS.append('-Wno-endif-labels') + self.CXXFLAGS.append('-Woverloaded-virtual') + self.CXXFLAGS.append('-Wsign-compare') + self.CXXFLAGS.append('-Wsign-promo') + self.CXXFLAGS.append('-Wstrict-null-sentinel') + self.CXXFLAGS.append('-Wwrite-strings') + self.CXXFLAGS.append('-Wno-old-style-cast') + self.CXXFLAGS.append('-Wno-deprecated') + self.CXXFLAGS.append('-Wno-strict-aliasing') + self.CXXFLAGS.append('-Werror') def option_pic(self, option=None, opt_str=None, value=None, parser=None): self.log.debug('Saw option --pic') - self.CXXFLAGS.append('-fPIC') + self.CXXFLAGS.append('-fPIC') def option_output(self, option=None, opt_str=None, value=None, parser=None): self.log.debug('Saw option --output') @@ -1142,6 +1189,14 @@ class PrepareBuild(CommandLineApp): ######################################################################### def locate_darwin_libraries(self): + match = re.search('gcc-mp-([0-9]+)\.([0-9]+)', self.envvars['CC']) + if match: + gcc_version = match.group(1) + match.group(2) + else: + gcc_version = "42" + + self.log.debug('Using gcc version: %s' % gcc_version) + if self.current_flavor == 'debug' or self.current_flavor == 'gcov': if self.options.use_glibcxx_debug: self.log.debug('We are using GLIBCXX_DEBUG, so setting up flags') @@ -1149,19 +1204,21 @@ class PrepareBuild(CommandLineApp): if self.boost_info.configure( home_path = '/usr/local/stow/boost_%s_0-gcc%s' % \ - (self.boost_version, self.gcc_version), + (self.boost_version, gcc_version), suffix = '-xgcc%s-sd-%s' % \ - (self.gcc_version, self.boost_version), + (gcc_version, self.boost_version), + file_suffix = '.dylib', include_path = 'include/boost-%s' % self.boost_version): pass elif self.boost_info.configure( home_path = '/usr/local/stow/boost_%s_0-gcc%s' % \ - (self.boost_version, self.gcc_version), + (self.boost_version, gcc_version), suffix = '-xgcc%s-d-%s' % \ - (self.gcc_version, self.boost_version), + (gcc_version, self.boost_version), + file_suffix = '.dylib', include_path = 'include/boost-%s' % self.boost_version): pass - elif self.boost_info.configure(suffix = '-d'): + elif self.boost_info.configure(suffix = '-d', file_suffix = '.dylib'): pass else: @@ -1169,16 +1226,18 @@ class PrepareBuild(CommandLineApp): pass elif self.boost_info.configure( home_path = '/usr/local/stow/boost_%s_0-gcc%s' % \ - (self.boost_version, self.gcc_version), + (self.boost_version, gcc_version), suffix = '-xgcc%s-s-%s' % \ - (self.gcc_version, self.boost_version), + (gcc_version, self.boost_version), + file_suffix = '.dylib', include_path = 'include/boost-%s' % self.boost_version): pass elif self.boost_info.configure( home_path = '/usr/local/stow/boost_%s_0-gcc%s' % \ - (self.boost_version, self.gcc_version), + (self.boost_version, gcc_version), suffix = '-xgcc%s-%s' % \ - (self.gcc_version, self.boost_version), + (gcc_version, self.boost_version), + file_suffix = '.dylib', include_path = 'include/boost-%s' % self.boost_version): pass @@ -1522,6 +1581,7 @@ class PrepareBuild(CommandLineApp): self.configure_flavor('default', reset=False) self.log.info('=== Testing default ===') self.phase_make('fullcheck') + self.phase_make('docs') self.log.info('=== Building final distcheck ===') self.phase_distcheck() diff --git a/contrib/vim/syntax/ledger.vim b/contrib/vim/syntax/ledger.vim index c96e4c3c..61f9a2e5 100644 --- a/contrib/vim/syntax/ledger.vim +++ b/contrib/vim/syntax/ledger.vim @@ -43,14 +43,24 @@ let s:currency = '\([$€£¢]\|\w\+\)' let s:figures = '\d\+\([.,]\d\+\)*' let s:amount = '-\?\('.s:figures.'\s*'.s:currency.'\|'.s:currency.'\s*'.s:figures.'\)' exe 'syn match Amount /'.s:amount.'/ contained' -syn match MetadataTag /:\zs[^:]\+\ze:\|;\s*\zs[^:]\+\ze:[^:]\+$/ contained +syn match MetadataTag /:[^:]\+:/hs=s+1,he=e-1 contained +syn match MetadataTag /;\s*\zs[^:]\+\ze:[^:]\+$/ contained +syn region TagStack + \ matchgroup=TagPush start=/^tag\>/ + \ matchgroup=TagPop end=/^pop\>/ + \ contains=TagHead,TagStack,transNorm +syn match TagHead /\%(^tag\s\+\)\@<=\S.*$/ contained contains=tagKey transparent +syn match TagKey /:[^:]\+:/hs=s+1,he=e-1 contained +syn match TagKey /\%(^tag\s\+\)\@<=[^:]\+\ze:[^:]\+$/ contained highlight default link transDate Constant highlight default link Metadata Tag highlight default link MetadataTag Type +highlight default link TagPop Tag +highlight default link TagPush Tag +highlight default link TagKey Type highlight default link Amount Number -highlight default link Comment Comment highlight default link Account Identifier " syncinc is easy: search for the first transaction. diff --git a/dist/Portfile b/dist/Portfile index c7305e96..fc82b3d3 100644 --- a/dist/Portfile +++ b/dist/Portfile @@ -3,45 +3,48 @@ PortSystem 1.0 -name ledger -version 3.0 +name ledger-devel +version 3.0-20100611 homepage http://www.newartisans.com/software/ledger.html categories finance accounting reporting description A command-line, double-entry accounting tool. long_description Ledger is a powerful, double-entry accounting system that \ - is accessed from the UNIX command-line. + is accessed from the UNIX command-line. maintainers johnw@newartisans.com platforms darwin -use_bzip2 no -master_sites ftp://ftp.newartisans.com/pub/ledger/:source +use_bzip2 yes +master_sites http://ftp.newartisans.com/pub/ledger/:source distname ${name}-${version} distfiles ${distname}${extract.suffix}:source checksums ${distname}${extract.suffix} \ - md5 7d2ebb3fbc0ca14e34f4aada9fe764a0 \ - sha1 d00ca4d61f28793c22be892411491d5ff48f156b \ - rmd160 e6ef6e0acfa125a88927ac399ec8e37fbbe1fe66 + md5 0ab9a855719df536a85f7ea5238b8a6e \ + sha1 e2ee9e2951fd37bac50c91046f097c11294a6e8e \ + rmd160 72cdfe76add63425b1ade1d03479e837e9f2dafe depends_build port:automake \ port:autoconf \ port:libtool -depends_lib port:gmp \ +depends_lib port:gettext \ + port:gmp \ port:mpfr \ - port:boost + port:boost \ + port:libedit -configure.args --with-extra-includes=${prefix}/include \ - --with-extra-libs=${prefix}/lib +# gmp and mpfr are not universal +universal_variant no -#patchfiles patch-admin-libtool.m4.in.diff \ -# patch-ledger-ProjectFile.cpp.diff +configure.args --with-extra-includes=${prefix}/include \ + --with-extra-libs=${prefix}/lib build.args DYLD_LIBRARY_PATH=${worksrcpath}/ledger/.libs platform darwin 9 {} +platform darwin 10 {} destroot.args DESTDIR=${destroot}${prefix} \ DYLD_LIBRARY_PATH=${worksrcpath}/ledger/.libs \ @@ -49,26 +52,49 @@ destroot.args DESTDIR=${destroot}${prefix} \ post-destroot {} -variant ofx description {Allow reading of OFX data files} { - depends_lib-append port:libofx -} - variant debug description {Enable debug mode} { configure.args-append --enable-debug=yes } +variant icu description {Enable full Unicode support} { + if {[variant_isset python25]} { + depends_lib-delete port:boost+python25 + depends_lib-append port:boost+icu+python25 + } + else if {[variant_isset python26]} { + depends_lib-delete port:boost+python26 + depends_lib-append port:boost+icu+python26 + } + else { + depends_lib-delete port:boost + depends_lib-append port:boost+icu + } +} + variant python25 description {build python 2.5 support} conflicts python26 { - set pyversion 2.5 - depends_lib-delete port:boost - depends_lib-append port:boost+python25 \ - port:python[strsed ${pyversion} {g/[.]//}] + set pyversion 2.5 + if {[variant_isset icu]} { + depends_lib-delete port:boost+icu + depends_lib-append port:boost+icu+python25 + } + else { + depends_lib-delete port:boost + depends_lib-append port:boost+python25 + } + depends_lib-append port:python25 } variant python26 description {build python 2.6 support} conflicts python25 { - set pyversion 2.6 - depends_lib-delete port:boost - depends_lib-append port:boost+python26 \ - port:python[strsed ${pyversion} {g/[.]//}] + set pyversion 2.6 + if {[variant_isset icu]} { + depends_lib-delete port:boost+icu + depends_lib-append port:boost+icu+python26 + } + else { + depends_lib-delete port:boost + depends_lib-append port:boost+python26 + } + depends_lib-append port:python26 } #livecheck.check regex @@ -1,4 +1,4 @@ - Ledger NEWS + Ledger NEWS * 3.0 @@ -291,7 +291,7 @@ features, please see the manual. monthly costs report, for example, because it makes the following command possible: - ledger -M --only "a>100" reg ^Expenses:Food + ledger -M --only "a>100" reg ^Expenses:Food This shows only *months* whose amount is greater than 100. If --limit had been used, it would have been a monthly summary of @@ -303,7 +303,7 @@ features, please see the manual. This predicate does not constrain calculation, but only display. Consider the same command as above: - ledger -M --display "a>100" reg ^Expenses:Food + ledger -M --display "a>100" reg ^Expenses:Food This displays only lines whose amount is greater than 100, *yet the running total still includes amounts from all transactions*. @@ -311,7 +311,7 @@ features, please see the manual. the current month's checking register while still giving a correct ending balance: - ledger --display "d>[this month]" reg Checking + ledger --display "d>[this month]" reg Checking Note that these predicates can be combined. Here is a report that considers only food bills whose individual cost is greater than @@ -320,8 +320,8 @@ features, please see the manual. retain an accurate running total with respect to the entire ledger file: - ledger -M --limit "a>20" --only "a>200" \ - --display "year == yearof([last year])" reg ^Expenses:Food + ledger -M --limit "a>20" --only "a>200" \ + --display "year == yearof([last year])" reg ^Expenses:Food - Added new "--descend AMOUNT" and "--descend-if VALEXPR" reporting options. For any reports that display valued transactions (i.e., @@ -398,12 +398,12 @@ features, please see the manual. G gain_total U(x) abs(x) S(x) quant(x), quantity(x) - comm(x), commodity(x) - setcomm(x,y), set_commodity(x,y) + comm(x), commodity(x) + setcomm(x,y), set_commodity(x,y) A(x) mean(x), avg(x), average(x) P(x,y) val(x,y), value(x,y) - min(x,y) - max(x,y) + min(x,y) + max(x,y) - There are new "parse" and "expr" commands, whose argument is a single value expression. Ledger will simply print out the result of @@ -554,10 +554,10 @@ features, please see the manual. the following is now supported, which wasn't previously: 2004/06/21 Adjustment - Retirement 100 FUNDA - Retirement 200 FUNDB - Retirement 300 FUNDC - Equity:Adjustments + Retirement 100 FUNDA + Retirement 200 FUNDB + Retirement 300 FUNDC + Equity:Adjustments - Fixed several bugs relating to QIF parsing, budgeting and forecasting. @@ -1,7 +1,7 @@ - Welcome to Ledger + Welcome to Ledger - the command-line accounting program + the command-line accounting program Introduction ============ diff --git a/doc/grammar.y b/doc/grammar.y index 018e7391..9a5f740b 100644 --- a/doc/grammar.y +++ b/doc/grammar.y @@ -53,7 +53,7 @@ journal_item: whitespace: EOL | WHITESPACE EOL | - ';' TEXT EOL | /* these next four are all ignored */ + ';' TEXT EOL | /* these next four are all ignored */ '*' TEXT EOL | ; @@ -70,23 +70,23 @@ word_directive: "end" | "alias" STRING '=' TEXT | "def" TEXT | - TEXT WHITESPACE TEXT /* looked up in session (aka maybe Python) */ + TEXT WHITESPACE TEXT /* looked up in session (aka maybe Python) */ ; char_directive: - 'i' date time TEXT | /* a timeclock.el "check in" */ + 'i' date time TEXT | /* a timeclock.el "check in" */ 'I' date time TEXT | - 'o' date time TEXT | /* a timeclock.el "check out" */ + 'o' date time TEXT | /* a timeclock.el "check out" */ 'O' date time TEXT | 'h' TEXT EOL | 'b' TEXT EOL | - 'D' amount | /* sets display parameters for a commodity */ - 'A' TEXT | /* sets the "default balancing account" */ - 'C' commodity '=' amount | /* specifies a commodity conversion */ + 'D' amount | /* sets display parameters for a commodity */ + 'A' TEXT | /* sets the "default balancing account" */ + 'C' commodity '=' amount | /* specifies a commodity conversion */ 'P' date time commodity amount | /* a pricing history xact */ - 'N' commodity | /* commodity's price is never downloaded */ - 'Y' INT4 | /* sets the default year for date parsing */ - '-' '-' STRING TEXT | /* specify command-line options in the file */ + 'N' commodity | /* commodity's price is never downloaded */ + 'Y' INT4 | /* sets the default year for date parsing */ + '-' '-' STRING TEXT | /* specify command-line options in the file */ ; date: INT4 date_sep INT2 date_sep INT2 ; @@ -210,7 +210,7 @@ values_opt: price_opt: price | /* epsilon */ ; price: '@' amount_expr | - '@@' amount_expr /* in this case, it's the whole price */ + '@@' amount_expr /* in this case, it's the whole price */ ; account: diff --git a/doc/ledger.texi b/doc/ledger.texi index 19588b68..2efb4054 100644 --- a/doc/ledger.texi +++ b/doc/ledger.texi @@ -35,7 +35,7 @@ THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. @end copying -@documentencoding utf-8 +@documentencoding UTF-8 @iftex @finalout diff --git a/lib/Makefile b/lib/Makefile index e9708d28..e52764bc 100644 --- a/lib/Makefile +++ b/lib/Makefile @@ -70,3 +70,7 @@ clean: -rm -fr $(STOW_ROOT)/icu-gcc$(CXX_VERSION) -(cd cppunit; make distclean) -(cd icu/source; make distclean) + +lib-clean: + -(cd cppunit; make distclean) + -(cd icu/source; make distclean) diff --git a/lisp/ldg-complete.el b/lisp/ldg-complete.el index 33a734b3..7b4b0471 100644 --- a/lisp/ldg-complete.el +++ b/lisp/ldg-complete.el @@ -8,46 +8,46 @@ (let ((here (point))) (goto-char (line-beginning-position)) (cond ((looking-at "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.+?)\\)?\\s-+") - (goto-char (match-end 0)) - 'entry) - ((looking-at "^\\s-+\\([*!]\\s-+\\)?[[(]?\\(.\\)") - (goto-char (match-beginning 2)) - 'transaction) - ((looking-at "^\\(sun\\|mon\\|tue\\|wed\\|thu\\|fri\\|sat\\)\\s-+") - (goto-char (match-end 0)) - 'entry) - (t - (ignore (goto-char here)))))) + (goto-char (match-end 0)) + 'entry) + ((looking-at "^\\s-+\\([*!]\\s-+\\)?[[(]?\\(.\\)") + (goto-char (match-beginning 2)) + 'transaction) + ((looking-at "^\\(sun\\|mon\\|tue\\|wed\\|thu\\|fri\\|sat\\)\\s-+") + (goto-char (match-end 0)) + 'entry) + (t + (ignore (goto-char here)))))) (defun ledger-parse-arguments () "Parse whitespace separated arguments in the current region." (let* ((info (save-excursion - (cons (ledger-thing-at-point) (point)))) - (begin (cdr info)) - (end (point)) - begins args) + (cons (ledger-thing-at-point) (point)))) + (begin (cdr info)) + (end (point)) + begins args) (save-excursion (goto-char begin) (when (< (point) end) - (skip-chars-forward " \t\n") - (setq begins (cons (point) begins)) - (setq args (cons (buffer-substring-no-properties - (car begins) end) - args))) + (skip-chars-forward " \t\n") + (setq begins (cons (point) begins)) + (setq args (cons (buffer-substring-no-properties + (car begins) end) + args))) (cons (reverse args) (reverse begins))))) (defun ledger-entries () (let ((origin (point)) - entries-list) + entries-list) (save-excursion (goto-char (point-min)) (while (re-search-forward - (concat "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.*?)\\)?\\s-+" - "\\(.+?\\)\\(\t\\|\n\\| [ \t]\\)") nil t) - (unless (and (>= origin (match-beginning 0)) - (< origin (match-end 0))) - (setq entries-list (cons (match-string-no-properties 3) - entries-list))))) + (concat "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.*?)\\)?\\s-+" + "\\(.+?\\)\\(\t\\|\n\\| [ \t]\\)") nil t) + (unless (and (>= origin (match-beginning 0)) + (< origin (match-end 0))) + (setq entries-list (cons (match-string-no-properties 3) + entries-list))))) (pcomplete-uniqify-list (nreverse entries-list)))) (defvar ledger-account-tree nil) @@ -58,99 +58,99 @@ (setq ledger-account-tree (list t)) (goto-char (point-min)) (while (re-search-forward - "^[ \t]+\\([*!]\\s-+\\)?[[(]?\\(.+?\\)\\(\t\\|\n\\| [ \t]\\)" nil t) - (unless (and (>= origin (match-beginning 0)) - (< origin (match-end 0))) - (setq account-path (match-string-no-properties 2)) - (setq elements (split-string account-path ":")) - (let ((root ledger-account-tree)) - (while elements - (let ((entry (assoc (car elements) root))) - (if entry - (setq root (cdr entry)) - (setq entry (cons (car elements) (list t))) - (nconc root (list entry)) - (setq root (cdr entry)))) - (setq elements (cdr elements))))))))) + "^[ \t]+\\([*!]\\s-+\\)?[[(]?\\(.+?\\)\\(\t\\|\n\\| [ \t]\\)" nil t) + (unless (and (>= origin (match-beginning 0)) + (< origin (match-end 0))) + (setq account-path (match-string-no-properties 2)) + (setq elements (split-string account-path ":")) + (let ((root ledger-account-tree)) + (while elements + (let ((entry (assoc (car elements) root))) + (if entry + (setq root (cdr entry)) + (setq entry (cons (car elements) (list t))) + (nconc root (list entry)) + (setq root (cdr entry)))) + (setq elements (cdr elements))))))))) (defun ledger-accounts () (ledger-find-accounts) (let* ((current (caar (ledger-parse-arguments))) - (elements (and current (split-string current ":"))) - (root ledger-account-tree) - (prefix nil)) + (elements (and current (split-string current ":"))) + (root ledger-account-tree) + (prefix nil)) (while (cdr elements) (let ((entry (assoc (car elements) root))) - (if entry - (setq prefix (concat prefix (and prefix ":") - (car elements)) - root (cdr entry)) - (setq root nil elements nil))) + (if entry + (setq prefix (concat prefix (and prefix ":") + (car elements)) + root (cdr entry)) + (setq root nil elements nil))) (setq elements (cdr elements))) (and root - (sort - (mapcar (function - (lambda (x) - (let ((term (if prefix - (concat prefix ":" (car x)) - (car x)))) - (if (> (length (cdr x)) 1) - (concat term ":") - term)))) - (cdr root)) - 'string-lessp)))) + (sort + (mapcar (function + (lambda (x) + (let ((term (if prefix + (concat prefix ":" (car x)) + (car x)))) + (if (> (length (cdr x)) 1) + (concat term ":") + term)))) + (cdr root)) + 'string-lessp)))) (defun ledger-complete-at-point () "Do appropriate completion for the thing at point" (interactive) (while (pcomplete-here - (if (eq (save-excursion - (ledger-thing-at-point)) 'entry) - (if (null current-prefix-arg) - (ledger-entries) ; this completes against entry names - (progn - (let ((text (buffer-substring (line-beginning-position) - (line-end-position)))) - (delete-region (line-beginning-position) - (line-end-position)) - (condition-case err - (ledger-add-entry text t) - ((error) - (insert text)))) - (forward-line) - (goto-char (line-end-position)) - (search-backward ";" (line-beginning-position) t) - (skip-chars-backward " \t0123456789.,") - (throw 'pcompleted t))) - (ledger-accounts))))) + (if (eq (save-excursion + (ledger-thing-at-point)) 'entry) + (if (null current-prefix-arg) + (ledger-entries) ; this completes against entry names + (progn + (let ((text (buffer-substring (line-beginning-position) + (line-end-position)))) + (delete-region (line-beginning-position) + (line-end-position)) + (condition-case err + (ledger-add-entry text t) + ((error) + (insert text)))) + (forward-line) + (goto-char (line-end-position)) + (search-backward ";" (line-beginning-position) t) + (skip-chars-backward " \t0123456789.,") + (throw 'pcompleted t))) + (ledger-accounts))))) (defun ledger-fully-complete-entry () "Do appropriate completion for the thing at point" (interactive) (let ((name (caar (ledger-parse-arguments))) - xacts) + xacts) (save-excursion (when (eq 'entry (ledger-thing-at-point)) - (when (re-search-backward - (concat "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.*?)\\)?\\s-+" - (regexp-quote name) "\\(\t\\|\n\\| [ \t]\\)") nil t) - (forward-line) - (while (looking-at "^\\s-+") - (setq xacts (cons (buffer-substring-no-properties - (line-beginning-position) - (line-end-position)) - xacts)) - (forward-line)) - (setq xacts (nreverse xacts))))) + (when (re-search-backward + (concat "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.*?)\\)?\\s-+" + (regexp-quote name) "\\(\t\\|\n\\| [ \t]\\)") nil t) + (forward-line) + (while (looking-at "^\\s-+") + (setq xacts (cons (buffer-substring-no-properties + (line-beginning-position) + (line-end-position)) + xacts)) + (forward-line)) + (setq xacts (nreverse xacts))))) (when xacts (save-excursion - (insert ?\n) - (while xacts - (insert (car xacts) ?\n) - (setq xacts (cdr xacts)))) + (insert ?\n) + (while xacts + (insert (car xacts) ?\n) + (setq xacts (cdr xacts)))) (forward-line) (goto-char (line-end-position)) (if (re-search-backward "\\(\t\\| [ \t]\\)" nil t) - (goto-char (match-end 0)))))) + (goto-char (match-end 0)))))) (provide 'ldg-complete) diff --git a/lisp/ldg-exec.el b/lisp/ldg-exec.el index 3881f8e9..bf3565b4 100644 --- a/lisp/ldg-exec.el +++ b/lisp/ldg-exec.el @@ -12,15 +12,15 @@ (if (null ledger-binary-path) (error "The variable `ledger-binary-path' has not been set")) (let ((buf (or input-buffer (current-buffer))) - (outbuf (or output-buffer - (generate-new-buffer " *ledger-tmp*")))) + (outbuf (or output-buffer + (generate-new-buffer " *ledger-tmp*")))) (with-current-buffer buf (let ((coding-system-for-write 'utf-8) - (coding-system-for-read 'utf-8)) - (apply #'call-process-region - (append (list (point-min) (point-max) - ledger-binary-path nil outbuf nil "-f" "-") - args))) + (coding-system-for-read 'utf-8)) + (apply #'call-process-region + (append (list (point-min) (point-max) + ledger-binary-path nil outbuf nil "-f" "-") + args))) outbuf))) (defun ledger-exec-read (&optional input-buffer &rest args) @@ -28,7 +28,7 @@ (apply #'ledger-exec-ledger input-buffer nil "emacs" args) (goto-char (point-min)) (prog1 - (read (current-buffer)) + (read (current-buffer)) (kill-buffer (current-buffer))))) (provide 'ldg-exec) diff --git a/lisp/ldg-mode.el b/lisp/ldg-mode.el index 973b891c..3e9a9106 100644 --- a/lisp/ldg-mode.el +++ b/lisp/ldg-mode.el @@ -5,13 +5,13 @@ (defvar bold 'bold) (defvar ledger-font-lock-keywords - '(("\\( \\| \\|^\\)\\(;.*\\)" 2 font-lock-comment-face) - ("^[0-9]+[-/.=][-/.=0-9]+\\s-+\\(([^)]+)\\s-+\\)?\\([^*].+?\\)\\(\\( ;\\| ;\\|$\\)\\)" 2 bold) - ;;("^[0-9]+[-/.=][-/.=0-9]+\\s-+\\(([^)]+)\\s-+\\)?\\([*].+?\\)\\(\\( ;\\| ;\\|$\\)\\)" + '(("\\( \\| \\|^\\)\\(;.*\\)" 2 font-lock-comment-face) + ("^[0-9]+[-/.=][-/.=0-9]+\\s-+\\(([^)]+)\\s-+\\)?\\([^*].+?\\)\\(\\( ;\\| ;\\|$\\)\\)" 2 bold) + ;;("^[0-9]+[-/.=][-/.=0-9]+\\s-+\\(([^)]+)\\s-+\\)?\\([*].+?\\)\\(\\( ;\\| ;\\|$\\)\\)" ;; 2 font-lock-type-face) ("^\\s-+\\([*]\\s-*\\)?\\(\\([[(]\\)?[^*: - ]+?:[^]); - ]+?\\([])]\\)?\\)\\( \\| \\|$\\)" + ]+?:[^]); + ]+?\\([])]\\)?\\)\\( \\| \\|$\\)" 2 font-lock-keyword-face) ("^\\([~=].+\\)" 1 font-lock-function-name-face) ("^\\([A-Za-z]+ .+\\)" 1 font-lock-function-name-face)) @@ -30,7 +30,7 @@ (if (boundp 'font-lock-defaults) (set (make-local-variable 'font-lock-defaults) - '(ledger-font-lock-keywords nil t))) + '(ledger-font-lock-keywords nil t))) (set (make-local-variable 'pcomplete-parse-arguments-function) 'ledger-parse-arguments) @@ -56,58 +56,58 @@ "Say whether time value T1 is less than time value T2." (or (< (car t1) (car t2)) (and (= (car t1) (car t2)) - (< (nth 1 t1) (nth 1 t2))))) + (< (nth 1 t1) (nth 1 t2))))) (defun ledger-time-subtract (t1 t2) "Subtract two time values. Return the difference in the format of a time value." (let ((borrow (< (cadr t1) (cadr t2)))) (list (- (car t1) (car t2) (if borrow 1 0)) - (- (+ (if borrow 65536 0) (cadr t1)) (cadr t2))))) + (- (+ (if borrow 65536 0) (cadr t1)) (cadr t2))))) (defun ledger-find-slot (moment) (catch 'found (ledger-iterate-entries (function (lambda (start date mark desc) - (if (ledger-time-less-p moment date) - (throw 'found t))))))) + (if (ledger-time-less-p moment date) + (throw 'found t))))))) (defun ledger-add-entry (entry-text &optional insert-at-point) (interactive "sEntry: ") (let* ((args (with-temp-buffer - (insert entry-text) - (eshell-parse-arguments (point-min) (point-max)))) - (ledger-buf (current-buffer)) - exit-code) + (insert entry-text) + (eshell-parse-arguments (point-min) (point-max)))) + (ledger-buf (current-buffer)) + exit-code) (unless insert-at-point (let ((date (car args))) - (if (string-match "\\([0-9]+\\)/\\([0-9]+\\)/\\([0-9]+\\)" date) - (setq date - (encode-time 0 0 0 (string-to-number (match-string 3 date)) - (string-to-number (match-string 2 date)) - (string-to-number (match-string 1 date))))) - (ledger-find-slot date))) + (if (string-match "\\([0-9]+\\)/\\([0-9]+\\)/\\([0-9]+\\)" date) + (setq date + (encode-time 0 0 0 (string-to-number (match-string 3 date)) + (string-to-number (match-string 2 date)) + (string-to-number (match-string 1 date))))) + (ledger-find-slot date))) (save-excursion (insert (with-temp-buffer - (setq exit-code - (apply #'ledger-run-ledger ledger-buf "entry" - (mapcar 'eval args))) - (goto-char (point-min)) - (if (looking-at "Error: ") - (error (buffer-string)) - (buffer-string))) + (setq exit-code + (apply #'ledger-run-ledger ledger-buf "entry" + (mapcar 'eval args))) + (goto-char (point-min)) + (if (looking-at "Error: ") + (error (buffer-string)) + (buffer-string))) "\n")))) (defun ledger-current-entry-bounds () (save-excursion (when (or (looking-at "^[0-9]") - (re-search-backward "^[0-9]" nil t)) + (re-search-backward "^[0-9]" nil t)) (let ((beg (point))) - (while (not (eolp)) - (forward-line)) - (cons (copy-marker beg) (point-marker)))))) + (while (not (eolp)) + (forward-line)) + (cons (copy-marker beg) (point-marker)))))) (defun ledger-delete-current-entry () (interactive) diff --git a/lisp/ldg-post.el b/lisp/ldg-post.el index 492f9467..da4a2806 100644 --- a/lisp/ldg-post.el +++ b/lisp/ldg-post.el @@ -26,14 +26,14 @@ (defun ledger-post-all-accounts () (let ((origin (point)) - (ledger-post-list nil) - account elements) + (ledger-post-list nil) + account elements) (save-excursion (goto-char (point-min)) (while (re-search-forward ledger-post-line-regexp nil t) - (unless (and (>= origin (match-beginning 0)) - (< origin (match-end 0))) - (add-to-list 'ledger-post-list (ledger-regex-post-line-account)))) + (unless (and (>= origin (match-beginning 0)) + (< origin (match-end 0))) + (add-to-list 'ledger-post-list (ledger-regex-post-line-account)))) (nreverse ledger-post-list)))) (declare-function iswitchb-read-buffer "iswitchb" @@ -47,9 +47,9 @@ to choose from." (cond (ledger-post-use-iswitchb (let* ((iswitchb-use-virtual-buffers nil) - (iswitchb-make-buflist-hook - (lambda () - (setq iswitchb-temp-buflist choices)))) + (iswitchb-make-buflist-hook + (lambda () + (setq iswitchb-temp-buflist choices)))) (iswitchb-read-buffer prompt))) (ledger-post-use-ido (ido-completing-read prompt choices)) @@ -61,26 +61,26 @@ to choose from." (defun ledger-post-pick-account () (interactive) (let* ((account - (ledger-post-completing-read - "Account: " (or ledger-post-current-list - (setq ledger-post-current-list - (ledger-post-all-accounts))))) - (account-len (length account)) - (pos (point))) + (ledger-post-completing-read + "Account: " (or ledger-post-current-list + (setq ledger-post-current-list + (ledger-post-all-accounts))))) + (account-len (length account)) + (pos (point))) (goto-char (line-beginning-position)) (when (re-search-forward ledger-post-line-regexp (line-end-position) t) (let ((existing-len (length (ledger-regex-post-line-account)))) - (goto-char (match-beginning ledger-regex-post-line-group-account)) - (delete-region (match-beginning ledger-regex-post-line-group-account) - (match-end ledger-regex-post-line-group-account)) - (insert account) - (cond - ((> existing-len account-len) - (insert (make-string (- existing-len account-len) ? ))) - ((< existing-len account-len) - (dotimes (n (- account-len existing-len)) - (if (looking-at "[ \t]\\( [ \t]\\|\t\\)") - (delete-char 1))))))) + (goto-char (match-beginning ledger-regex-post-line-group-account)) + (delete-region (match-beginning ledger-regex-post-line-group-account) + (match-end ledger-regex-post-line-group-account)) + (insert account) + (cond + ((> existing-len account-len) + (insert (make-string (- existing-len account-len) ? ))) + ((< existing-len account-len) + (dotimes (n (- account-len existing-len)) + (if (looking-at "[ \t]\\( [ \t]\\|\t\\)") + (delete-char 1))))))) (goto-char pos))) (defun ledger-next-amount (&optional end) @@ -88,7 +88,7 @@ to choose from." (goto-char (match-beginning 0)) (skip-syntax-forward " ") (- (or (match-end 4) - (match-end 3)) (point)))) + (match-end 3)) (point)))) (defun ledger-align-amounts (&optional column) "Align amounts in the current region. @@ -98,24 +98,24 @@ This is done so that the last digit falls in COLUMN, which defaults to 52." (setq column ledger-post-amount-alignment-column)) (save-excursion (let* ((mark-first (< (mark) (point))) - (begin (if mark-first (mark) (point))) - (end (if mark-first (point-marker) (mark-marker))) - offset) + (begin (if mark-first (mark) (point))) + (end (if mark-first (point-marker) (mark-marker))) + offset) (goto-char begin) (while (setq offset (ledger-next-amount end)) - (let ((col (current-column)) - (target-col (- column offset)) - adjust) - (setq adjust (- target-col col)) - (if (< col target-col) - (insert (make-string (- target-col col) ? )) - (move-to-column target-col) - (if (looking-back " ") - (delete-char (- col target-col)) - (skip-chars-forward "^ \t") - (delete-horizontal-space) - (insert " "))) - (forward-line)))))) + (let ((col (current-column)) + (target-col (- column offset)) + adjust) + (setq adjust (- target-col col)) + (if (< col target-col) + (insert (make-string (- target-col col) ? )) + (move-to-column target-col) + (if (looking-back " ") + (delete-char (- col target-col)) + (skip-chars-forward "^ \t") + (delete-horizontal-space) + (insert " "))) + (forward-line)))))) (defun ledger-post-align-amount () (interactive) @@ -130,7 +130,7 @@ This is done so that the last digit falls in COLUMN, which defaults to 52." (when (< end (line-end-position)) (goto-char (line-beginning-position)) (if (looking-at ledger-post-line-regexp) - (ledger-post-align-amount))))) + (ledger-post-align-amount))))) (defun ledger-post-edit-amount () (interactive) @@ -139,12 +139,12 @@ This is done so that the last digit falls in COLUMN, which defaults to 52." (goto-char (match-end ledger-regex-post-line-group-account)) (when (re-search-forward "[-.,0-9]+" (line-end-position) t) (let ((val (match-string 0))) - (goto-char (match-beginning 0)) - (delete-region (match-beginning 0) (match-end 0)) - (calc) - (while (string-match "," val) - (setq val (replace-match "" nil nil val))) - (calc-eval val 'push))))) + (goto-char (match-beginning 0)) + (delete-region (match-beginning 0) (match-end 0)) + (calc) + (while (string-match "," val) + (setq val (replace-match "" nil nil val))) + (calc-eval val 'push))))) (defun ledger-post-prev-xact () (interactive) diff --git a/lisp/ldg-reconcile.el b/lisp/ldg-reconcile.el index 3be882f4..baeadc33 100644 --- a/lisp/ldg-reconcile.el +++ b/lisp/ldg-reconcile.el @@ -5,41 +5,41 @@ (defun ledger-display-balance () (let ((buffer ledger-buf) - (account ledger-acct)) + (account ledger-acct)) (with-temp-buffer (let ((exit-code (ledger-run-ledger buffer "-C" "balance" account))) - (if (/= 0 exit-code) - (message "Error determining cleared balance") - (goto-char (1- (point-max))) - (goto-char (line-beginning-position)) - (delete-horizontal-space) - (message "Cleared balance = %s" - (buffer-substring-no-properties (point) - (line-end-position)))))))) + (if (/= 0 exit-code) + (message "Error determining cleared balance") + (goto-char (1- (point-max))) + (goto-char (line-beginning-position)) + (delete-horizontal-space) + (message "Cleared balance = %s" + (buffer-substring-no-properties (point) + (line-end-position)))))))) (defun ledger-reconcile-toggle () (interactive) (let ((where (get-text-property (point) 'where)) - (account ledger-acct) - (inhibit-read-only t) - cleared) + (account ledger-acct) + (inhibit-read-only t) + cleared) (when (or (equal (car where) "<stdin>") (equal (car where) "/dev/stdin")) (with-current-buffer ledger-buf - (goto-char (cdr where)) - (setq cleared (ledger-toggle-current 'pending))) + (goto-char (cdr where)) + (setq cleared (ledger-toggle-current 'pending))) (if cleared - (add-text-properties (line-beginning-position) - (line-end-position) - (list 'face 'bold)) - (remove-text-properties (line-beginning-position) - (line-end-position) - (list 'face)))) + (add-text-properties (line-beginning-position) + (line-end-position) + (list 'face 'bold)) + (remove-text-properties (line-beginning-position) + (line-end-position) + (list 'face)))) (forward-line))) (defun ledger-reconcile-refresh () (interactive) (let ((inhibit-read-only t) - (line (count-lines (point-min) (point)))) + (line (count-lines (point-min) (point)))) (erase-buffer) (ledger-do-reconcile) (set-buffer-modified-p t) @@ -49,9 +49,9 @@ (defun ledger-reconcile-refresh-after-save () (let ((buf (get-buffer "*Reconcile*"))) (if buf - (with-current-buffer buf - (ledger-reconcile-refresh) - (set-buffer-modified-p nil))))) + (with-current-buffer buf + (ledger-reconcile-refresh) + (set-buffer-modified-p nil))))) (defun ledger-reconcile-add () (interactive) @@ -64,12 +64,12 @@ (let ((where (get-text-property (point) 'where))) (when (or (equal (car where) "<stdin>") (equal (car where) "/dev/stdin")) (with-current-buffer ledger-buf - (goto-char (cdr where)) - (ledger-delete-current-entry)) + (goto-char (cdr where)) + (ledger-delete-current-entry)) (let ((inhibit-read-only t)) - (goto-char (line-beginning-position)) - (delete-region (point) (1+ (line-end-position))) - (set-buffer-modified-p t))))) + (goto-char (line-beginning-position)) + (delete-region (point) (1+ (line-end-position))) + (set-buffer-modified-p t))))) (defun ledger-reconcile-visit () (interactive) @@ -95,12 +95,12 @@ (goto-char (point-min)) (while (not (eobp)) (let ((where (get-text-property (point) 'where)) - (face (get-text-property (point) 'face))) - (if (and (eq face 'bold) - (or (equal (car where) "<stdin>") (equal (car where) "/dev/stdin"))) - (with-current-buffer ledger-buf - (goto-char (cdr where)) - (ledger-toggle-current 'cleared)))) + (face (get-text-property (point) 'face))) + (if (and (eq face 'bold) + (or (equal (car where) "<stdin>") (equal (car where) "/dev/stdin"))) + (with-current-buffer ledger-buf + (goto-char (cdr where)) + (ledger-toggle-current 'cleared)))) (forward-line 1))) (ledger-reconcile-save)) @@ -110,12 +110,12 @@ (defun ledger-reconcile (account) (interactive "sAccount to reconcile: ") (let ((buf (current-buffer)) - (rbuf (get-buffer "*Reconcile*"))) + (rbuf (get-buffer "*Reconcile*"))) (if rbuf - (kill-buffer rbuf)) + (kill-buffer rbuf)) (add-hook 'after-save-hook 'ledger-reconcile-refresh-after-save) (with-current-buffer - (pop-to-buffer (get-buffer-create "*Reconcile*")) + (pop-to-buffer (get-buffer-create "*Reconcile*")) (ledger-reconcile-mode) (set (make-local-variable 'ledger-buf) buf) (set (make-local-variable 'ledger-acct) account) diff --git a/lisp/ldg-regex.el b/lisp/ldg-regex.el index 93ef6b09..1c6b8f06 100644 --- a/lisp/ldg-regex.el +++ b/lisp/ldg-regex.el @@ -6,112 +6,112 @@ (defmacro ledger-define-regexp (name regex docs &rest args) "Simplify the creation of a Ledger regex and helper functions." (let ((defs - (list - `(defconst - ,(intern (concat "ledger-" (symbol-name name) "-regexp")) - ,(eval regex)))) - (addend 0) last-group) + (list + `(defconst + ,(intern (concat "ledger-" (symbol-name name) "-regexp")) + ,(eval regex)))) + (addend 0) last-group) (if (null args) - (progn - (nconc - defs - (list - `(defconst - ,(intern - (concat "ledger-regex-" (symbol-name name) "-group")) - 1))) - (nconc - defs - (list - `(defconst - ,(intern (concat "ledger-regex-" (symbol-name name) - "-group--count")) - 1))) - (nconc - defs - (list - `(defmacro - ,(intern (concat "ledger-regex-" (symbol-name name))) - (&optional string) - ,(format "Return the match string for the %s" name) - (match-string - ,(intern (concat "ledger-regex-" (symbol-name name) - "-group")) - string))))) + (progn + (nconc + defs + (list + `(defconst + ,(intern + (concat "ledger-regex-" (symbol-name name) "-group")) + 1))) + (nconc + defs + (list + `(defconst + ,(intern (concat "ledger-regex-" (symbol-name name) + "-group--count")) + 1))) + (nconc + defs + (list + `(defmacro + ,(intern (concat "ledger-regex-" (symbol-name name))) + (&optional string) + ,(format "Return the match string for the %s" name) + (match-string + ,(intern (concat "ledger-regex-" (symbol-name name) + "-group")) + string))))) (dolist (arg args) - (let (var grouping target) - (if (symbolp arg) - (setq var arg target arg) - (assert (listp arg)) - (if (= 2 (length arg)) - (setq var (car arg) - target (cadr arg)) - (setq var (car arg) - grouping (cadr arg) - target (caddr arg)))) - - (if (and last-group - (not (eq last-group (or grouping target)))) - (incf addend - (symbol-value - (intern-soft (concat "ledger-regex-" - (symbol-name last-group) - "-group--count"))))) - (nconc - defs - (list - `(defconst - ,(intern (concat "ledger-regex-" (symbol-name name) - "-group-" (symbol-name var))) - ,(+ addend - (symbol-value - (intern-soft - (if grouping - (concat "ledger-regex-" (symbol-name grouping) - "-group-" (symbol-name target)) - (concat "ledger-regex-" (symbol-name target) - "-group")))))))) - (nconc - defs - (list - `(defmacro - ,(intern (concat "ledger-regex-" (symbol-name name) - "-" (symbol-name var))) - (&optional string) - ,(format "Return the sub-group match for the %s %s." - name var) - (match-string - ,(intern (concat "ledger-regex-" (symbol-name name) - "-group-" (symbol-name var))) - string)))) - - (setq last-group (or grouping target)))) + (let (var grouping target) + (if (symbolp arg) + (setq var arg target arg) + (assert (listp arg)) + (if (= 2 (length arg)) + (setq var (car arg) + target (cadr arg)) + (setq var (car arg) + grouping (cadr arg) + target (caddr arg)))) + + (if (and last-group + (not (eq last-group (or grouping target)))) + (incf addend + (symbol-value + (intern-soft (concat "ledger-regex-" + (symbol-name last-group) + "-group--count"))))) + (nconc + defs + (list + `(defconst + ,(intern (concat "ledger-regex-" (symbol-name name) + "-group-" (symbol-name var))) + ,(+ addend + (symbol-value + (intern-soft + (if grouping + (concat "ledger-regex-" (symbol-name grouping) + "-group-" (symbol-name target)) + (concat "ledger-regex-" (symbol-name target) + "-group")))))))) + (nconc + defs + (list + `(defmacro + ,(intern (concat "ledger-regex-" (symbol-name name) + "-" (symbol-name var))) + (&optional string) + ,(format "Return the sub-group match for the %s %s." + name var) + (match-string + ,(intern (concat "ledger-regex-" (symbol-name name) + "-group-" (symbol-name var))) + string)))) + + (setq last-group (or grouping target)))) (nconc defs - (list - `(defconst ,(intern (concat "ledger-regex-" (symbol-name name) - "-group--count")) - ,(length args))))) + (list + `(defconst ,(intern (concat "ledger-regex-" (symbol-name name) + "-group--count")) + ,(length args))))) (cons 'progn defs))) (put 'ledger-define-regexp 'lisp-indent-function 1) (ledger-define-regexp date - (let ((sep '(or ?- (any ?. ?/)))) ; can't do (any ?- ?. ?/) due to bug + (let ((sep '(or ?- (any ?. ?/)))) ; can't do (any ?- ?. ?/) due to bug (rx (group - (and (? (= 4 num) - (eval sep)) - (and num (? num)) - (eval sep) - (and num (? num)))))) + (and (? (= 4 num) + (eval sep)) + (and num (? num)) + (eval sep) + (and num (? num)))))) "Match a single date, in its 'written' form.") (ledger-define-regexp full-date (macroexpand `(rx (and (regexp ,ledger-date-regexp) - (? (and ?= (regexp ,ledger-date-regexp)))))) + (? (and ?= (regexp ,ledger-date-regexp)))))) "Match a compound date, of the form ACTUAL=EFFECTIVE" (actual date) (effective date)) @@ -126,7 +126,7 @@ (ledger-define-regexp long-space (rx (and (*? blank) - (or (and ? (or ? ?\t)) ?\t))) + (or (and ? (or ? ?\t)) ?\t))) "Match a \"long space\".") (ledger-define-regexp note @@ -136,24 +136,24 @@ (ledger-define-regexp end-note (macroexpand `(rx (and (regexp ,ledger-long-space-regexp) ?\; - (regexp ,ledger-note-regexp)))) + (regexp ,ledger-note-regexp)))) "") (ledger-define-regexp full-note (macroexpand `(rx (and line-start (+ blank) - ?\; (regexp ,ledger-note-regexp)))) + ?\; (regexp ,ledger-note-regexp)))) "") (ledger-define-regexp xact-line (macroexpand `(rx (and line-start - (regexp ,ledger-full-date-regexp) - (? (and (+ blank) (regexp ,ledger-state-regexp))) - (? (and (+ blank) (regexp ,ledger-code-regexp))) - (+ blank) (+? nonl) - (? (regexp ,ledger-end-note-regexp)) - line-end))) + (regexp ,ledger-full-date-regexp) + (? (and (+ blank) (regexp ,ledger-state-regexp))) + (? (and (+ blank) (regexp ,ledger-code-regexp))) + (+ blank) (+? nonl) + (? (regexp ,ledger-end-note-regexp)) + line-end))) "Match a transaction's first line (and optional notes)." (actual-date full-date actual) (effective-date full-date effective) @@ -172,8 +172,8 @@ (ledger-define-regexp full-account (macroexpand `(rx (and (regexp ,ledger-account-kind-regexp) - (regexp ,ledger-account-regexp) - (? (any ?\] ?\)))))) + (regexp ,ledger-account-regexp) + (? (any ?\] ?\)))))) "" (kind account-kind) (name account)) @@ -181,50 +181,50 @@ (ledger-define-regexp commodity (rx (group (or (and ?\" (+ (not (any ?\"))) ?\") - (not (any blank ?\n - digit - ?- ?\[ ?\] - ?. ?, ?\; ?+ ?* ?/ ?^ ?? ?: ?& ?| ?! ?= - ?\< ?\> ?\{ ?\} ?\( ?\) ?@))))) + (not (any blank ?\n + digit + ?- ?\[ ?\] + ?. ?, ?\; ?+ ?* ?/ ?^ ?? ?: ?& ?| ?! ?= + ?\< ?\> ?\{ ?\} ?\( ?\) ?@))))) "") (ledger-define-regexp amount (rx (group (and (? ?-) - (and (+ digit) - (*? (and (any ?. ?,) (+ digit)))) - (? (and (any ?. ?,) (+ digit)))))) + (and (+ digit) + (*? (and (any ?. ?,) (+ digit)))) + (? (and (any ?. ?,) (+ digit)))))) "") (ledger-define-regexp commoditized-amount (macroexpand `(rx (group - (or (and (regexp ,ledger-commodity-regexp) - (*? blank) - (regexp ,ledger-amount-regexp)) - (and (regexp ,ledger-amount-regexp) - (*? blank) - (regexp ,ledger-commodity-regexp)))))) + (or (and (regexp ,ledger-commodity-regexp) + (*? blank) + (regexp ,ledger-amount-regexp)) + (and (regexp ,ledger-amount-regexp) + (*? blank) + (regexp ,ledger-commodity-regexp)))))) "") (ledger-define-regexp commodity-annotations (macroexpand `(rx (* (+ blank) - (or (and ?\{ (regexp ,ledger-commoditized-amount-regexp) ?\}) - (and ?\[ (regexp ,ledger-date-regexp) ?\]) - (and ?\( (not (any ?\))) ?\)))))) + (or (and ?\{ (regexp ,ledger-commoditized-amount-regexp) ?\}) + (and ?\[ (regexp ,ledger-date-regexp) ?\]) + (and ?\( (not (any ?\))) ?\)))))) "") (ledger-define-regexp cost (macroexpand `(rx (and (or "@" "@@") (+ blank) - (regexp ,ledger-commoditized-amount-regexp)))) + (regexp ,ledger-commoditized-amount-regexp)))) "") (ledger-define-regexp balance-assertion (macroexpand `(rx (and ?= (+ blank) - (regexp ,ledger-commoditized-amount-regexp)))) + (regexp ,ledger-commoditized-amount-regexp)))) "") (ledger-define-regexp full-amount @@ -234,12 +234,12 @@ (ledger-define-regexp post-line (macroexpand `(rx (and line-start (+ blank) - (? (and (regexp ,ledger-state-regexp) (* blank))) - (regexp ,ledger-full-account-regexp) - (? (and (regexp ,ledger-long-space-regexp) - (regexp ,ledger-full-amount-regexp))) - (? (regexp ,ledger-end-note-regexp)) - line-end))) + (? (and (regexp ,ledger-state-regexp) (* blank))) + (regexp ,ledger-full-account-regexp) + (? (and (regexp ,ledger-long-space-regexp) + (regexp ,ledger-full-amount-regexp))) + (? (regexp ,ledger-end-note-regexp)) + line-end))) "" state (account-kind full-account kind) diff --git a/lisp/ldg-register.el b/lisp/ldg-register.el index 02e50de9..7b5c0d0a 100644 --- a/lisp/ldg-register.el +++ b/lisp/ldg-register.el @@ -25,29 +25,29 @@ (dolist (post posts) (let ((index 1)) (dolist (xact (nthcdr 5 post)) - (let ((beg (point)) - (where - (with-current-buffer data-buffer - (cons - (nth 0 post) - (if ledger-clear-whole-entries - (save-excursion - (goto-line (nth 1 post)) - (point-marker)) - (save-excursion - (goto-line (nth 0 xact)) - (point-marker))))))) - (insert (format ledger-register-line-format - (format-time-string ledger-register-date-format - (nth 2 post)) - (nth 4 post) (nth 1 xact) (nth 2 xact))) - (if (nth 3 xact) - (set-text-properties beg (1- (point)) - (list 'face 'ledger-register-pending-face - 'where where)) - (set-text-properties beg (1- (point)) - (list 'where where)))) - (setq index (1+ index))))) + (let ((beg (point)) + (where + (with-current-buffer data-buffer + (cons + (nth 0 post) + (if ledger-clear-whole-entries + (save-excursion + (goto-line (nth 1 post)) + (point-marker)) + (save-excursion + (goto-line (nth 0 xact)) + (point-marker))))))) + (insert (format ledger-register-line-format + (format-time-string ledger-register-date-format + (nth 2 post)) + (nth 4 post) (nth 1 xact) (nth 2 xact))) + (if (nth 3 xact) + (set-text-properties beg (1- (point)) + (list 'face 'ledger-register-pending-face + 'where where)) + (set-text-properties beg (1- (point)) + (list 'where where)))) + (setq index (1+ index))))) (goto-char (point-min)) ) @@ -55,10 +55,10 @@ (let ((buf (or data-buffer (current-buffer)))) (with-current-buffer (get-buffer-create "*ledger-register*") (let ((pos (point)) - (inhibit-read-only t)) - (erase-buffer) - (ledger-register-render buf (apply #'ledger-exec-read buf args)) - (goto-char pos)) + (inhibit-read-only t)) + (erase-buffer) + (ledger-register-render buf (apply #'ledger-exec-read buf args)) + (goto-char pos)) (set-buffer-modified-p nil) (toggle-read-only t) (display-buffer (current-buffer) t)))) diff --git a/lisp/ldg-report.el b/lisp/ldg-report.el index 6fc74f1d..5a668847 100644 --- a/lisp/ldg-report.el +++ b/lisp/ldg-report.el @@ -15,7 +15,7 @@ the substitution. See the documentation of the individual functions in that variable for more information on the behavior of each specifier." :type '(repeat (list (string :tag "Report Name") - (string :tag "Command Line"))) + (string :tag "Command Line"))) :group 'ledger) (defcustom ledger-report-format-specifiers @@ -73,8 +73,8 @@ text that should replace the format specifier." The empty string and unknown names are allowed." (completing-read "Report name: " - ledger-reports nil nil nil - 'ledger-report-name-prompt-history nil)) + ledger-reports nil nil nil + 'ledger-report-name-prompt-history nil)) (defun ledger-report (report-name edit) "Run a user-specified report from `ledger-reports'. @@ -93,18 +93,18 @@ used to generate the buffer, navigating the buffer, etc." (interactive (progn (when (and (buffer-modified-p) - (y-or-n-p "Buffer modified, save it? ")) + (y-or-n-p "Buffer modified, save it? ")) (save-buffer)) (let ((rname (ledger-report-read-name)) - (edit (not (null current-prefix-arg)))) + (edit (not (null current-prefix-arg)))) (list rname edit)))) (let ((buf (current-buffer)) - (rbuf (get-buffer ledger-report-buffer-name)) - (wcfg (current-window-configuration))) + (rbuf (get-buffer ledger-report-buffer-name)) + (wcfg (current-window-configuration))) (if rbuf - (kill-buffer rbuf)) + (kill-buffer rbuf)) (with-current-buffer - (pop-to-buffer (get-buffer-create ledger-report-buffer-name)) + (pop-to-buffer (get-buffer-create ledger-report-buffer-name)) (ledger-report-mode) (set (make-local-variable 'ledger-buf) buf) (set (make-local-variable 'ledger-report-name) report-name) @@ -137,8 +137,8 @@ If name exists, returns the object naming the report, otherwise returns nil." (defun ledger-report-read-command (report-cmd) "Read the command line to create a report." (read-from-minibuffer "Report command line: " - (if (null report-cmd) "ledger " report-cmd) - nil nil 'ledger-report-cmd-prompt-history)) + (if (null report-cmd) "ledger " report-cmd) + nil nil 'ledger-report-cmd-prompt-history)) (defun ledger-report-ledger-file-format-specifier () "Substitute the full path to master or current ledger file @@ -165,9 +165,9 @@ end of a ledger file which is included in some other file." (defun ledger-read-string-with-default (prompt default) (let ((default-prompt (concat prompt - (if default - (concat " (" default "): ") - ": ")))) + (if default + (concat " (" default "): ") + ": ")))) (read-string default-prompt nil nil default))) (defun ledger-report-payee-format-specifier () @@ -191,26 +191,26 @@ the default." ;; It is intended completion should be available on existing account ;; names, but it remains to be implemented. (let* ((context (ledger-context-at-point)) - (default - (if (eq (ledger-context-line-type context) 'acct-transaction) - (regexp-quote (ledger-context-field-value context 'account)) - nil))) + (default + (if (eq (ledger-context-line-type context) 'acct-transaction) + (regexp-quote (ledger-context-field-value context 'account)) + nil))) (ledger-read-string-with-default "Account" default))) (defun ledger-report-expand-format-specifiers (report-cmd) (let ((expanded-cmd report-cmd)) (while (string-match "%(\\([^)]*\\))" expanded-cmd) (let* ((specifier (match-string 1 expanded-cmd)) - (f (cdr (assoc specifier ledger-report-format-specifiers)))) - (if f - (setq expanded-cmd (replace-match - (save-match-data - (with-current-buffer ledger-buf - (shell-quote-argument (funcall f)))) - t t expanded-cmd)) - (progn - (set-window-configuration ledger-original-window-cfg) - (error "Invalid ledger report format specifier '%s'" specifier))))) + (f (cdr (assoc specifier ledger-report-format-specifiers)))) + (if f + (setq expanded-cmd (replace-match + (save-match-data + (with-current-buffer ledger-buf + (shell-quote-argument (funcall f)))) + t t expanded-cmd)) + (progn + (set-window-configuration ledger-original-window-cfg) + (error "Invalid ledger report format specifier '%s'" specifier))))) expanded-cmd)) (defun ledger-report-cmd (report-name edit) @@ -222,18 +222,18 @@ the default." (setq report-cmd (ledger-report-expand-format-specifiers report-cmd)) (set (make-local-variable 'ledger-report-cmd) report-cmd) (or (string-empty-p report-name) - (ledger-report-name-exists report-name) - (ledger-reports-add report-name report-cmd) - (ledger-reports-custom-save)) + (ledger-report-name-exists report-name) + (ledger-reports-add report-name report-cmd) + (ledger-reports-custom-save)) report-cmd)) (defun ledger-do-report (cmd) "Run a report command line." (goto-char (point-min)) (insert (format "Report: %s\n" ledger-report-name) - (format "Command: %s\n" cmd) - (make-string (- (window-width) 1) ?=) - "\n") + (format "Command: %s\n" cmd) + (make-string (- (window-width) 1) ?=) + "\n") (shell-command cmd t nil)) (defun ledger-report-goto () @@ -241,7 +241,7 @@ the default." (interactive) (let ((rbuf (get-buffer ledger-report-buffer-name))) (if (not rbuf) - (error "There is no ledger report buffer")) + (error "There is no ledger report buffer")) (pop-to-buffer rbuf) (shrink-window-if-larger-than-buffer))) @@ -277,7 +277,7 @@ the default." (let ((name "")) (while (string-empty-p name) (setq name (read-from-minibuffer "Report name: " nil nil nil - 'ledger-report-name-prompt-history))) + 'ledger-report-name-prompt-history))) name)) (defun ledger-report-save () @@ -290,15 +290,15 @@ the default." (while (setq existing-name (ledger-report-name-exists ledger-report-name)) (cond ((y-or-n-p (format "Overwrite existing report named '%s' " - ledger-report-name)) - (when (string-equal - ledger-report-cmd - (car (cdr (assq existing-name ledger-reports)))) - (error "Current command is identical to existing saved one")) - (setq ledger-reports - (assq-delete-all existing-name ledger-reports))) - (t - (setq ledger-report-name (ledger-report-read-new-name))))) + ledger-report-name)) + (when (string-equal + ledger-report-cmd + (car (cdr (assq existing-name ledger-reports)))) + (error "Current command is identical to existing saved one")) + (setq ledger-reports + (assq-delete-all existing-name ledger-reports))) + (t + (setq ledger-report-name (ledger-report-read-new-name))))) (ledger-reports-add ledger-report-name ledger-report-cmd) (ledger-reports-custom-save))) @@ -333,24 +333,24 @@ the default." Assumes point is at beginning of line, and the pos argument specifies where the \"users\" point was." (let ((linfo (assoc line-type ledger-line-config)) - found field fields) + found field fields) (dolist (re-info (nth 1 linfo)) (let ((re (nth 0 re-info)) - (names (nth 1 re-info))) - (unless found - (when (looking-at re) - (setq found t) - (dotimes (i (length names)) - (when (nth i names) - (setq fields (append fields - (list - (list (nth i names) - (match-string-no-properties (1+ i)) - (match-beginning (1+ i)))))))) - (dolist (f fields) - (and (nth 1 f) - (>= pos (nth 2 f)) - (setq field (nth 0 f)))))))) + (names (nth 1 re-info))) + (unless found + (when (looking-at re) + (setq found t) + (dotimes (i (length names)) + (when (nth i names) + (setq fields (append fields + (list + (list (nth i names) + (match-string-no-properties (1+ i)) + (match-beginning (1+ i)))))))) + (dolist (f fields) + (and (nth 1 f) + (>= pos (nth 2 f)) + (setq field (nth 0 f)))))))) (list line-type field fields))) (defun ledger-context-at-point () @@ -363,40 +363,40 @@ the fields in the line in a association list." (save-excursion (beginning-of-line) (let ((first-char (char-after))) - (cond ((equal (point) (line-end-position)) - '(empty-line nil nil)) - ((memq first-char '(?\ ?\t)) - (ledger-extract-context-info 'acct-transaction pos)) - ((memq first-char '(?0 ?1 ?2 ?3 ?4 ?5 ?6 ?7 ?8 ?9)) - (ledger-extract-context-info 'entry pos)) - ((equal first-char ?\=) - '(automated-entry nil nil)) - ((equal first-char ?\~) - '(period-entry nil nil)) - ((equal first-char ?\!) - '(command-directive)) - ((equal first-char ?\;) - '(comment nil nil)) - ((equal first-char ?Y) - '(default-year nil nil)) - ((equal first-char ?P) - '(commodity-price nil nil)) - ((equal first-char ?N) - '(price-ignored-commodity nil nil)) - ((equal first-char ?D) - '(default-commodity nil nil)) - ((equal first-char ?C) - '(commodity-conversion nil nil)) - ((equal first-char ?i) - '(timeclock-i nil nil)) - ((equal first-char ?o) - '(timeclock-o nil nil)) - ((equal first-char ?b) - '(timeclock-b nil nil)) - ((equal first-char ?h) - '(timeclock-h nil nil)) - (t - '(unknown nil nil))))))) + (cond ((equal (point) (line-end-position)) + '(empty-line nil nil)) + ((memq first-char '(?\ ?\t)) + (ledger-extract-context-info 'acct-transaction pos)) + ((memq first-char '(?0 ?1 ?2 ?3 ?4 ?5 ?6 ?7 ?8 ?9)) + (ledger-extract-context-info 'entry pos)) + ((equal first-char ?\=) + '(automated-entry nil nil)) + ((equal first-char ?\~) + '(period-entry nil nil)) + ((equal first-char ?\!) + '(command-directive)) + ((equal first-char ?\;) + '(comment nil nil)) + ((equal first-char ?Y) + '(default-year nil nil)) + ((equal first-char ?P) + '(commodity-price nil nil)) + ((equal first-char ?N) + '(price-ignored-commodity nil nil)) + ((equal first-char ?D) + '(default-commodity nil nil)) + ((equal first-char ?C) + '(commodity-conversion nil nil)) + ((equal first-char ?i) + '(timeclock-i nil nil)) + ((equal first-char ?o) + '(timeclock-o nil nil)) + ((equal first-char ?b) + '(timeclock-b nil nil)) + ((equal first-char ?h) + '(timeclock-h nil nil)) + (t + '(unknown nil nil))))))) (defun ledger-context-other-line (offset) "Return a list describing context of line offset for existing position. @@ -406,8 +406,8 @@ specified line, returns nil." (save-excursion (let ((left (forward-line offset))) (if (not (equal left 0)) - nil - (ledger-context-at-point))))) + nil + (ledger-context-at-point))))) (defun ledger-context-line-type (context-info) (nth 0 context-info)) @@ -444,5 +444,5 @@ specified line, returns nil." (setq i (- i 1))) (let ((context-info (ledger-context-other-line i))) (if (eq (ledger-context-line-type context-info) 'entry) - (ledger-context-field-value context-info 'payee) - nil)))) + (ledger-context-field-value context-info 'payee) + nil)))) diff --git a/lisp/ldg-state.el b/lisp/ldg-state.el index 945d72fe..6a841621 100644 --- a/lisp/ldg-state.el +++ b/lisp/ldg-state.el @@ -6,28 +6,28 @@ (defun ledger-toggle-state (state &optional style) (if (not (null state)) (if (and style (eq style 'cleared)) - 'cleared) + 'cleared) (if (and style (eq style 'pending)) - 'pending + 'pending 'cleared))) (defun ledger-entry-state () (save-excursion (when (or (looking-at "^[0-9]") - (re-search-backward "^[0-9]" nil t)) + (re-search-backward "^[0-9]" nil t)) (skip-chars-forward "0-9./=") (skip-syntax-forward " ") (cond ((looking-at "!\\s-*") 'pending) - ((looking-at "\\*\\s-*") 'cleared) - (t nil))))) + ((looking-at "\\*\\s-*") 'cleared) + (t nil))))) (defun ledger-transaction-state () (save-excursion (goto-char (line-beginning-position)) (skip-syntax-forward " ") (cond ((looking-at "!\\s-*") 'pending) - ((looking-at "\\*\\s-*") 'cleared) - (t (ledger-entry-state))))) + ((looking-at "\\*\\s-*") 'cleared) + (t (ledger-entry-state))))) (defun ledger-toggle-current-transaction (&optional style) "Toggle the cleared status of the transaction under point. @@ -42,129 +42,129 @@ formatting, but doing so causes inline math expressions to be dropped." (interactive) (let ((bounds (ledger-current-entry-bounds)) - clear cleared) + clear cleared) ;; Uncompact the entry, to make it easier to toggle the ;; transaction (save-excursion (goto-char (car bounds)) (skip-chars-forward "0-9./= \t") (setq cleared (and (member (char-after) '(?\* ?\!)) - (char-after))) + (char-after))) (when cleared - (let ((here (point))) - (skip-chars-forward "*! ") - (let ((width (- (point) here))) - (when (> width 0) - (delete-region here (point)) - (if (search-forward " " (line-end-position) t) - (insert (make-string width ? )))))) - (forward-line) - (while (looking-at "[ \t]") - (skip-chars-forward " \t") - (insert cleared " ") - (if (search-forward " " (line-end-position) t) - (delete-char 2)) - (forward-line)))) + (let ((here (point))) + (skip-chars-forward "*! ") + (let ((width (- (point) here))) + (when (> width 0) + (delete-region here (point)) + (if (search-forward " " (line-end-position) t) + (insert (make-string width ? )))))) + (forward-line) + (while (looking-at "[ \t]") + (skip-chars-forward " \t") + (insert cleared " ") + (if (search-forward " " (line-end-position) t) + (delete-char 2)) + (forward-line)))) ;; Toggle the individual transaction (save-excursion (goto-char (line-beginning-position)) (when (looking-at "[ \t]") - (skip-chars-forward " \t") - (let ((here (point)) - (cleared (member (char-after) '(?\* ?\!)))) - (skip-chars-forward "*! ") - (let ((width (- (point) here))) - (when (> width 0) - (delete-region here (point)) - (save-excursion - (if (search-forward " " (line-end-position) t) - (insert (make-string width ? )))))) - (let (inserted) - (if cleared - (if (and style (eq style 'cleared)) - (progn - (insert "* ") - (setq inserted t))) - (if (and style (eq style 'pending)) - (progn - (insert "! ") - (setq inserted t)) - (progn - (insert "* ") - (setq inserted t)))) - (if (and inserted - (re-search-forward "\\(\t\\| [ \t]\\)" - (line-end-position) t)) - (cond - ((looking-at "\t") - (delete-char 1)) - ((looking-at " [ \t]") - (delete-char 2)) - ((looking-at " ") - (delete-char 1)))) - (setq clear inserted))))) + (skip-chars-forward " \t") + (let ((here (point)) + (cleared (member (char-after) '(?\* ?\!)))) + (skip-chars-forward "*! ") + (let ((width (- (point) here))) + (when (> width 0) + (delete-region here (point)) + (save-excursion + (if (search-forward " " (line-end-position) t) + (insert (make-string width ? )))))) + (let (inserted) + (if cleared + (if (and style (eq style 'cleared)) + (progn + (insert "* ") + (setq inserted t))) + (if (and style (eq style 'pending)) + (progn + (insert "! ") + (setq inserted t)) + (progn + (insert "* ") + (setq inserted t)))) + (if (and inserted + (re-search-forward "\\(\t\\| [ \t]\\)" + (line-end-position) t)) + (cond + ((looking-at "\t") + (delete-char 1)) + ((looking-at " [ \t]") + (delete-char 2)) + ((looking-at " ") + (delete-char 1)))) + (setq clear inserted))))) ;; Clean up the entry so that it displays minimally (save-excursion (goto-char (car bounds)) (forward-line) (let ((first t) - (state ? ) - (hetero nil)) - (while (and (not hetero) (looking-at "[ \t]")) - (skip-chars-forward " \t") - (let ((cleared (if (member (char-after) '(?\* ?\!)) - (char-after) - ? ))) - (if first - (setq state cleared - first nil) - (if (/= state cleared) - (setq hetero t)))) - (forward-line)) - (when (and (not hetero) (/= state ? )) - (goto-char (car bounds)) - (forward-line) - (while (looking-at "[ \t]") - (skip-chars-forward " \t") - (let ((here (point))) - (skip-chars-forward "*! ") - (let ((width (- (point) here))) - (when (> width 0) - (delete-region here (point)) - (if (re-search-forward "\\(\t\\| [ \t]\\)" - (line-end-position) t) - (insert (make-string width ? )))))) - (forward-line)) - (goto-char (car bounds)) - (skip-chars-forward "0-9./= \t") - (insert state " ") - (if (re-search-forward "\\(\t\\| [ \t]\\)" - (line-end-position) t) - (cond - ((looking-at "\t") - (delete-char 1)) - ((looking-at " [ \t]") - (delete-char 2)) - ((looking-at " ") - (delete-char 1))))))) + (state ? ) + (hetero nil)) + (while (and (not hetero) (looking-at "[ \t]")) + (skip-chars-forward " \t") + (let ((cleared (if (member (char-after) '(?\* ?\!)) + (char-after) + ? ))) + (if first + (setq state cleared + first nil) + (if (/= state cleared) + (setq hetero t)))) + (forward-line)) + (when (and (not hetero) (/= state ? )) + (goto-char (car bounds)) + (forward-line) + (while (looking-at "[ \t]") + (skip-chars-forward " \t") + (let ((here (point))) + (skip-chars-forward "*! ") + (let ((width (- (point) here))) + (when (> width 0) + (delete-region here (point)) + (if (re-search-forward "\\(\t\\| [ \t]\\)" + (line-end-position) t) + (insert (make-string width ? )))))) + (forward-line)) + (goto-char (car bounds)) + (skip-chars-forward "0-9./= \t") + (insert state " ") + (if (re-search-forward "\\(\t\\| [ \t]\\)" + (line-end-position) t) + (cond + ((looking-at "\t") + (delete-char 1)) + ((looking-at " [ \t]") + (delete-char 2)) + ((looking-at " ") + (delete-char 1))))))) clear)) (defun ledger-toggle-current (&optional style) (interactive) (if (or ledger-clear-whole-entries - (eq 'entry (ledger-thing-at-point))) + (eq 'entry (ledger-thing-at-point))) (progn - (save-excursion - (forward-line) - (goto-char (line-beginning-position)) - (while (and (not (eolp)) - (save-excursion - (not (eq 'entry (ledger-thing-at-point))))) - (if (looking-at "\\s-+[*!]") - (ledger-toggle-current-transaction nil)) - (forward-line) - (goto-char (line-beginning-position)))) - (ledger-toggle-current-entry style)) + (save-excursion + (forward-line) + (goto-char (line-beginning-position)) + (while (and (not (eolp)) + (save-excursion + (not (eq 'entry (ledger-thing-at-point))))) + (if (looking-at "\\s-+[*!]") + (ledger-toggle-current-transaction nil)) + (forward-line) + (goto-char (line-beginning-position)))) + (ledger-toggle-current-entry style)) (ledger-toggle-current-transaction style))) (defun ledger-toggle-current-entry (&optional style) @@ -172,18 +172,18 @@ dropped." (let (clear) (save-excursion (when (or (looking-at "^[0-9]") - (re-search-backward "^[0-9]" nil t)) - (skip-chars-forward "0-9./=") - (delete-horizontal-space) - (if (member (char-after) '(?\* ?\!)) - (progn - (delete-char 1) - (if (and style (eq style 'cleared)) - (insert " *"))) - (if (and style (eq style 'pending)) - (insert " ! ") - (insert " * ")) - (setq clear t)))) + (re-search-backward "^[0-9]" nil t)) + (skip-chars-forward "0-9./=") + (delete-horizontal-space) + (if (member (char-after) '(?\* ?\!)) + (progn + (delete-char 1) + (if (and style (eq style 'cleared)) + (insert " *"))) + (if (and style (eq style 'pending)) + (insert " ! ") + (insert " * ")) + (setq clear t)))) clear)) (provide 'ldg-state) diff --git a/lisp/ldg-texi.el b/lisp/ldg-texi.el index 982ea0ed..9d5383eb 100644 --- a/lisp/ldg-texi.el +++ b/lisp/ldg-texi.el @@ -5,13 +5,13 @@ (defun ledger-texi-write-test (name command input output &optional category) (let ((buf (current-buffer))) (with-current-buffer (find-file-noselect - (expand-file-name (concat name ".test") category)) + (expand-file-name (concat name ".test") category)) (erase-buffer) (let ((case-fold-search nil)) - (if (string-match "\\$LEDGER\\s-+" command) - (setq command (replace-match "" t t command))) - (if (string-match " -f \\$\\([-a-z]+\\)" command) - (setq command (replace-match "" t t command)))) + (if (string-match "\\$LEDGER\\s-+" command) + (setq command (replace-match "" t t command))) + (if (string-match " -f \\$\\([-a-z]+\\)" command) + (setq command (replace-match "" t t command)))) (insert command ?\n) (insert "<<<" ?\n) (insert input) @@ -21,13 +21,13 @@ (insert "=== 0" ?\n) (save-buffer) (unless (eq buf (current-buffer)) - (kill-buffer (current-buffer)))))) + (kill-buffer (current-buffer)))))) (defun ledger-texi-update-test () (interactive) (let ((details (ledger-texi-test-details)) - (name (file-name-sans-extension - (file-name-nondirectory (buffer-file-name))))) + (name (file-name-sans-extension + (file-name-nondirectory (buffer-file-name))))) (ledger-texi-write-test name (nth 0 details) (nth 1 details) @@ -39,30 +39,30 @@ (defun ledger-texi-test-details () (goto-char (point-min)) (let ((command (buffer-substring (point) (line-end-position))) - input output) + input output) (re-search-forward "^<<<") (let ((input-beg (1+ (match-end 0)))) (re-search-forward "^>>>1") (let ((output-beg (1+ (match-end 0)))) - (setq input (buffer-substring input-beg (match-beginning 0))) - (re-search-forward "^>>>2") - (setq output (buffer-substring output-beg (match-beginning 0))) - (list command input output))))) + (setq input (buffer-substring input-beg (match-beginning 0))) + (re-search-forward "^>>>2") + (setq output (buffer-substring output-beg (match-beginning 0))) + (list command input output))))) (defun ledger-texi-expand-command (command data-file) (if (string-match "\\$LEDGER" command) (replace-match (format "%s -f \"%s\" %s" ledger-path - data-file ledger-normalization-args) t t command) + data-file ledger-normalization-args) t t command) (concat (format "%s -f \"%s\" %s " ledger-path - data-file ledger-normalization-args) command))) + data-file ledger-normalization-args) command))) (defun ledger-texi-invoke-command (command) (with-temp-buffer (shell-command command t (current-buffer)) (if (= (point-min) (point-max)) - (progn - (push-mark nil t) - (message "Command '%s' yielded no result at %d" command (point)) - (ding)) + (progn + (push-mark nil t) + (message "Command '%s' yielded no result at %d" command (point)) + (ding)) (buffer-string)))) (defun ledger-texi-write-test-data (name input) @@ -79,43 +79,43 @@ (goto-char (point-min)) (while (re-search-forward "^@c \\(\\(?:sm\\)?ex\\) \\(\\S-+\\): \\(.*\\)" nil t) (let ((section (match-string 1)) - (example-name (match-string 2)) - (command (match-string 3)) expanded-command - (data-file ledger-sample-doc-path) - input output) - (goto-char (match-end 0)) - (forward-line) - (when (looking-at "@\\(\\(?:small\\)?example\\)") - (let ((beg (point))) - (re-search-forward "^@end \\(\\(?:small\\)?example\\)") - (delete-region beg (1+ (point))))) + (example-name (match-string 2)) + (command (match-string 3)) expanded-command + (data-file ledger-sample-doc-path) + input output) + (goto-char (match-end 0)) + (forward-line) + (when (looking-at "@\\(\\(?:small\\)?example\\)") + (let ((beg (point))) + (re-search-forward "^@end \\(\\(?:small\\)?example\\)") + (delete-region beg (1+ (point))))) - (when (let ((case-fold-search nil)) - (string-match " -f \\$\\([-a-z]+\\)" command)) - (let ((label (match-string 1 command))) - (setq command (replace-match "" t t command)) - (save-excursion - (goto-char (point-min)) - (search-forward (format "@c data: %s" label)) - (re-search-forward "@\\(\\(?:small\\)?example\\)") - (forward-line) - (let ((beg (point))) - (re-search-forward "@end \\(\\(?:small\\)?example\\)") - (setq data-file (ledger-texi-write-test-data - (format "%s.dat" label) - (buffer-substring-no-properties - beg (match-beginning 0)))))))) + (when (let ((case-fold-search nil)) + (string-match " -f \\$\\([-a-z]+\\)" command)) + (let ((label (match-string 1 command))) + (setq command (replace-match "" t t command)) + (save-excursion + (goto-char (point-min)) + (search-forward (format "@c data: %s" label)) + (re-search-forward "@\\(\\(?:small\\)?example\\)") + (forward-line) + (let ((beg (point))) + (re-search-forward "@end \\(\\(?:small\\)?example\\)") + (setq data-file (ledger-texi-write-test-data + (format "%s.dat" label) + (buffer-substring-no-properties + beg (match-beginning 0)))))))) - (let ((section-name (if (string= section "smex") - "smallexample" - "example")) - (output (ledger-texi-invoke-command - (ledger-texi-expand-command command data-file)))) - (insert "@" section-name ?\n output - "@end " section-name ?\n)) + (let ((section-name (if (string= section "smex") + "smallexample" + "example")) + (output (ledger-texi-invoke-command + (ledger-texi-expand-command command data-file)))) + (insert "@" section-name ?\n output + "@end " section-name ?\n)) - ;; Update the regression test associated with this example - (ledger-texi-write-test example-name command input output - "../test/manual"))))) + ;; Update the regression test associated with this example + (ledger-texi-write-test example-name command input output + "../test/manual"))))) (provide 'ldg-texi) diff --git a/lisp/ldg-xact.el b/lisp/ldg-xact.el index 5945632a..e1f165a7 100644 --- a/lisp/ldg-xact.el +++ b/lisp/ldg-xact.el @@ -9,12 +9,12 @@ nil (function (lambda () - (if (re-search-forward - (concat "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.*?)\\)?\\s-+" - "\\(.+?\\)\\(\t\\|\n\\| [ \t]\\)") nil t) - (goto-char (match-beginning 0)) - (goto-char (point-max))))) + (if (re-search-forward + (concat "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.*?)\\)?\\s-+" + "\\(.+?\\)\\(\t\\|\n\\| [ \t]\\)") nil t) + (goto-char (match-beginning 0)) + (goto-char (point-max))))) (function (lambda () - (forward-paragraph)))))) + (forward-paragraph)))))) diff --git a/lisp/ledger.el b/lisp/ledger.el index 0e2f4b11..25bb485b 100644 --- a/lisp/ledger.el +++ b/lisp/ledger.el @@ -107,7 +107,7 @@ the substitution. See the documentation of the individual functions in that variable for more information on the behavior of each specifier." :type '(repeat (list (string :tag "Report Name") - (string :tag "Command Line"))) + (string :tag "Command Line"))) :group 'ledger) (defcustom ledger-report-format-specifiers @@ -128,13 +128,13 @@ text that should replace the format specifier." (defvar bold 'bold) (defvar ledger-font-lock-keywords - '(("\\( \\| \\|^\\)\\(;.*\\)" 2 font-lock-comment-face) - ("^[0-9]+[-/.=][-/.=0-9]+\\s-+\\(([^)]+)\\s-+\\)?\\([^*].+?\\)\\(\\( ;\\| ;\\|$\\)\\)" 2 bold) - ;;("^[0-9]+[-/.=][-/.=0-9]+\\s-+\\(([^)]+)\\s-+\\)?\\([*].+?\\)\\(\\( ;\\| ;\\|$\\)\\)" + '(("\\( \\| \\|^\\)\\(;.*\\)" 2 font-lock-comment-face) + ("^[0-9]+[-/.=][-/.=0-9]+\\s-+\\(([^)]+)\\s-+\\)?\\([^*].+?\\)\\(\\( ;\\| ;\\|$\\)\\)" 2 bold) + ;;("^[0-9]+[-/.=][-/.=0-9]+\\s-+\\(([^)]+)\\s-+\\)?\\([*].+?\\)\\(\\( ;\\| ;\\|$\\)\\)" ;; 2 font-lock-type-face) ("^\\s-+\\([*]\\s-*\\)?\\(\\([[(]\\)?[^*: - ]+?:[^]); - ]+?\\([])]\\)?\\)\\( \\| \\|$\\)" + ]+?:[^]); + ]+?\\([])]\\)?\\)\\( \\| \\|$\\)" 2 font-lock-keyword-face) ("^\\([~=].+\\)" 1 font-lock-function-name-face) ("^\\([A-Za-z]+ .+\\)" 1 font-lock-function-name-face)) @@ -155,88 +155,88 @@ customizable to ease retro-entry.") (defun ledger-iterate-entries (callback) (goto-char (point-min)) (let* ((now (current-time)) - (current-year (nth 5 (decode-time now)))) + (current-year (nth 5 (decode-time now)))) (while (not (eobp)) (when (looking-at - (concat "\\(Y\\s-+\\([0-9]+\\)\\|" - "\\([0-9]\\{4\\}+\\)?[./]?" - "\\([0-9]+\\)[./]\\([0-9]+\\)\\s-+" - "\\(\\*\\s-+\\)?\\(.+\\)\\)")) - (let ((found (match-string 2))) - (if found - (setq current-year (string-to-number found)) - (let ((start (match-beginning 0)) - (year (match-string 3)) - (month (string-to-number (match-string 4))) - (day (string-to-number (match-string 5))) - (mark (match-string 6)) - (desc (match-string 7))) - (if (and year (> (length year) 0)) - (setq year (string-to-number year))) - (funcall callback start - (encode-time 0 0 0 day month - (or year current-year)) - mark desc))))) + (concat "\\(Y\\s-+\\([0-9]+\\)\\|" + "\\([0-9]\\{4\\}+\\)?[./]?" + "\\([0-9]+\\)[./]\\([0-9]+\\)\\s-+" + "\\(\\*\\s-+\\)?\\(.+\\)\\)")) + (let ((found (match-string 2))) + (if found + (setq current-year (string-to-number found)) + (let ((start (match-beginning 0)) + (year (match-string 3)) + (month (string-to-number (match-string 4))) + (day (string-to-number (match-string 5))) + (mark (match-string 6)) + (desc (match-string 7))) + (if (and year (> (length year) 0)) + (setq year (string-to-number year))) + (funcall callback start + (encode-time 0 0 0 day month + (or year current-year)) + mark desc))))) (forward-line)))) (defun ledger-time-less-p (t1 t2) "Say whether time value T1 is less than time value T2." (or (< (car t1) (car t2)) (and (= (car t1) (car t2)) - (< (nth 1 t1) (nth 1 t2))))) + (< (nth 1 t1) (nth 1 t2))))) (defun ledger-time-subtract (t1 t2) "Subtract two time values. Return the difference in the format of a time value." (let ((borrow (< (cadr t1) (cadr t2)))) (list (- (car t1) (car t2) (if borrow 1 0)) - (- (+ (if borrow 65536 0) (cadr t1)) (cadr t2))))) + (- (+ (if borrow 65536 0) (cadr t1)) (cadr t2))))) (defun ledger-find-slot (moment) (catch 'found (ledger-iterate-entries (function (lambda (start date mark desc) - (if (ledger-time-less-p moment date) - (throw 'found t))))))) + (if (ledger-time-less-p moment date) + (throw 'found t))))))) (defun ledger-add-entry (entry-text &optional insert-at-point) (interactive (list (read-string "Entry: " (concat ledger-year "/" ledger-month "/")))) (let* ((args (with-temp-buffer - (insert entry-text) - (eshell-parse-arguments (point-min) (point-max)))) - (ledger-buf (current-buffer)) - exit-code) + (insert entry-text) + (eshell-parse-arguments (point-min) (point-max)))) + (ledger-buf (current-buffer)) + exit-code) (unless insert-at-point (let ((date (car args))) - (if (string-match "\\([0-9]+\\)/\\([0-9]+\\)/\\([0-9]+\\)" date) - (setq date - (encode-time 0 0 0 (string-to-number (match-string 3 date)) - (string-to-number (match-string 2 date)) - (string-to-number (match-string 1 date))))) - (ledger-find-slot date))) + (if (string-match "\\([0-9]+\\)/\\([0-9]+\\)/\\([0-9]+\\)" date) + (setq date + (encode-time 0 0 0 (string-to-number (match-string 3 date)) + (string-to-number (match-string 2 date)) + (string-to-number (match-string 1 date))))) + (ledger-find-slot date))) (save-excursion (insert (with-temp-buffer - (setq exit-code - (apply #'ledger-run-ledger ledger-buf "entry" - (mapcar 'eval args))) - (goto-char (point-min)) - (if (looking-at "Error: ") - (error (buffer-string)) - (buffer-string))) + (setq exit-code + (apply #'ledger-run-ledger ledger-buf "entry" + (mapcar 'eval args))) + (goto-char (point-min)) + (if (looking-at "Error: ") + (error (buffer-string)) + (buffer-string))) "\n")))) (defun ledger-current-entry-bounds () (save-excursion (when (or (looking-at "^[0-9]") - (re-search-backward "^[0-9]" nil t)) + (re-search-backward "^[0-9]" nil t)) (let ((beg (point))) - (while (not (eolp)) - (forward-line)) - (cons (copy-marker beg) (point-marker)))))) + (while (not (eolp)) + (forward-line)) + (cons (copy-marker beg) (point-marker)))))) (defun ledger-delete-current-entry () (interactive) @@ -248,18 +248,18 @@ Return the difference in the format of a time value." (let (clear) (save-excursion (when (or (looking-at "^[0-9]") - (re-search-backward "^[0-9]" nil t)) - (skip-chars-forward "0-9./=") - (delete-horizontal-space) - (if (member (char-after) '(?\* ?\!)) - (progn - (delete-char 1) - (if (and style (eq style 'cleared)) - (insert " *"))) - (if (and style (eq style 'pending)) - (insert " ! ") - (insert " * ")) - (setq clear t)))) + (re-search-backward "^[0-9]" nil t)) + (skip-chars-forward "0-9./=") + (delete-horizontal-space) + (if (member (char-after) '(?\* ?\!)) + (progn + (delete-char 1) + (if (and style (eq style 'cleared)) + (insert " *"))) + (if (and style (eq style 'pending)) + (insert " ! ") + (insert " * ")) + (setq clear t)))) clear)) (defun ledger-move-to-next-field () @@ -268,28 +268,28 @@ Return the difference in the format of a time value." (defun ledger-toggle-state (state &optional style) (if (not (null state)) (if (and style (eq style 'cleared)) - 'cleared) + 'cleared) (if (and style (eq style 'pending)) - 'pending + 'pending 'cleared))) (defun ledger-entry-state () (save-excursion (when (or (looking-at "^[0-9]") - (re-search-backward "^[0-9]" nil t)) + (re-search-backward "^[0-9]" nil t)) (skip-chars-forward "0-9./=") (skip-syntax-forward " ") (cond ((looking-at "!\\s-*") 'pending) - ((looking-at "\\*\\s-*") 'cleared) - (t nil))))) + ((looking-at "\\*\\s-*") 'cleared) + (t nil))))) (defun ledger-transaction-state () (save-excursion (goto-char (line-beginning-position)) (skip-syntax-forward " ") (cond ((looking-at "!\\s-*") 'pending) - ((looking-at "\\*\\s-*") 'cleared) - (t (ledger-entry-state))))) + ((looking-at "\\*\\s-*") 'cleared) + (t (ledger-entry-state))))) (defun ledger-toggle-current-transaction (&optional style) "Toggle the cleared status of the transaction under point. @@ -304,129 +304,129 @@ formatting, but doing so causes inline math expressions to be dropped." (interactive) (let ((bounds (ledger-current-entry-bounds)) - clear cleared) + clear cleared) ;; Uncompact the entry, to make it easier to toggle the ;; transaction (save-excursion (goto-char (car bounds)) (skip-chars-forward "0-9./= \t") (setq cleared (and (member (char-after) '(?\* ?\!)) - (char-after))) + (char-after))) (when cleared - (let ((here (point))) - (skip-chars-forward "*! ") - (let ((width (- (point) here))) - (when (> width 0) - (delete-region here (point)) - (if (search-forward " " (line-end-position) t) - (insert (make-string width ? )))))) - (forward-line) - (while (looking-at "[ \t]") - (skip-chars-forward " \t") - (insert cleared " ") - (if (search-forward " " (line-end-position) t) - (delete-char 2)) - (forward-line)))) + (let ((here (point))) + (skip-chars-forward "*! ") + (let ((width (- (point) here))) + (when (> width 0) + (delete-region here (point)) + (if (search-forward " " (line-end-position) t) + (insert (make-string width ? )))))) + (forward-line) + (while (looking-at "[ \t]") + (skip-chars-forward " \t") + (insert cleared " ") + (if (search-forward " " (line-end-position) t) + (delete-char 2)) + (forward-line)))) ;; Toggle the individual transaction (save-excursion (goto-char (line-beginning-position)) (when (looking-at "[ \t]") - (skip-chars-forward " \t") - (let ((here (point)) - (cleared (member (char-after) '(?\* ?\!)))) - (skip-chars-forward "*! ") - (let ((width (- (point) here))) - (when (> width 0) - (delete-region here (point)) - (save-excursion - (if (search-forward " " (line-end-position) t) - (insert (make-string width ? )))))) - (let (inserted) - (if cleared - (if (and style (eq style 'cleared)) - (progn - (insert "* ") - (setq inserted t))) - (if (and style (eq style 'pending)) - (progn - (insert "! ") - (setq inserted t)) - (progn - (insert "* ") - (setq inserted t)))) - (if (and inserted - (re-search-forward "\\(\t\\| [ \t]\\)" - (line-end-position) t)) - (cond - ((looking-at "\t") - (delete-char 1)) - ((looking-at " [ \t]") - (delete-char 2)) - ((looking-at " ") - (delete-char 1)))) - (setq clear inserted))))) + (skip-chars-forward " \t") + (let ((here (point)) + (cleared (member (char-after) '(?\* ?\!)))) + (skip-chars-forward "*! ") + (let ((width (- (point) here))) + (when (> width 0) + (delete-region here (point)) + (save-excursion + (if (search-forward " " (line-end-position) t) + (insert (make-string width ? )))))) + (let (inserted) + (if cleared + (if (and style (eq style 'cleared)) + (progn + (insert "* ") + (setq inserted t))) + (if (and style (eq style 'pending)) + (progn + (insert "! ") + (setq inserted t)) + (progn + (insert "* ") + (setq inserted t)))) + (if (and inserted + (re-search-forward "\\(\t\\| [ \t]\\)" + (line-end-position) t)) + (cond + ((looking-at "\t") + (delete-char 1)) + ((looking-at " [ \t]") + (delete-char 2)) + ((looking-at " ") + (delete-char 1)))) + (setq clear inserted))))) ;; Clean up the entry so that it displays minimally (save-excursion (goto-char (car bounds)) (forward-line) (let ((first t) - (state ? ) - (hetero nil)) - (while (and (not hetero) (looking-at "[ \t]")) - (skip-chars-forward " \t") - (let ((cleared (if (member (char-after) '(?\* ?\!)) - (char-after) - ? ))) - (if first - (setq state cleared - first nil) - (if (/= state cleared) - (setq hetero t)))) - (forward-line)) - (when (and (not hetero) (/= state ? )) - (goto-char (car bounds)) - (forward-line) - (while (looking-at "[ \t]") - (skip-chars-forward " \t") - (let ((here (point))) - (skip-chars-forward "*! ") - (let ((width (- (point) here))) - (when (> width 0) - (delete-region here (point)) - (if (re-search-forward "\\(\t\\| [ \t]\\)" - (line-end-position) t) - (insert (make-string width ? )))))) - (forward-line)) - (goto-char (car bounds)) - (skip-chars-forward "0-9./= \t") - (insert state " ") - (if (re-search-forward "\\(\t\\| [ \t]\\)" - (line-end-position) t) - (cond - ((looking-at "\t") - (delete-char 1)) - ((looking-at " [ \t]") - (delete-char 2)) - ((looking-at " ") - (delete-char 1))))))) + (state ? ) + (hetero nil)) + (while (and (not hetero) (looking-at "[ \t]")) + (skip-chars-forward " \t") + (let ((cleared (if (member (char-after) '(?\* ?\!)) + (char-after) + ? ))) + (if first + (setq state cleared + first nil) + (if (/= state cleared) + (setq hetero t)))) + (forward-line)) + (when (and (not hetero) (/= state ? )) + (goto-char (car bounds)) + (forward-line) + (while (looking-at "[ \t]") + (skip-chars-forward " \t") + (let ((here (point))) + (skip-chars-forward "*! ") + (let ((width (- (point) here))) + (when (> width 0) + (delete-region here (point)) + (if (re-search-forward "\\(\t\\| [ \t]\\)" + (line-end-position) t) + (insert (make-string width ? )))))) + (forward-line)) + (goto-char (car bounds)) + (skip-chars-forward "0-9./= \t") + (insert state " ") + (if (re-search-forward "\\(\t\\| [ \t]\\)" + (line-end-position) t) + (cond + ((looking-at "\t") + (delete-char 1)) + ((looking-at " [ \t]") + (delete-char 2)) + ((looking-at " ") + (delete-char 1))))))) clear)) (defun ledger-toggle-current (&optional style) (interactive) (if (or ledger-clear-whole-entries - (eq 'entry (ledger-thing-at-point))) + (eq 'entry (ledger-thing-at-point))) (progn - (save-excursion - (forward-line) - (goto-char (line-beginning-position)) - (while (and (not (eolp)) - (save-excursion - (not (eq 'entry (ledger-thing-at-point))))) - (if (looking-at "\\s-+[*!]") - (ledger-toggle-current-transaction nil)) - (forward-line) - (goto-char (line-beginning-position)))) - (ledger-toggle-current-entry style)) + (save-excursion + (forward-line) + (goto-char (line-beginning-position)) + (while (and (not (eolp)) + (save-excursion + (not (eq 'entry (ledger-thing-at-point))))) + (if (looking-at "\\s-+[*!]") + (ledger-toggle-current-transaction nil)) + (forward-line) + (goto-char (line-beginning-position)))) + (ledger-toggle-current-entry style)) (ledger-toggle-current-transaction style))) (defvar ledger-mode-abbrev-table) @@ -440,7 +440,7 @@ dropped." (if (boundp 'font-lock-defaults) (set (make-local-variable 'font-lock-defaults) - '(ledger-font-lock-keywords nil t))) + '(ledger-font-lock-keywords nil t))) (set (make-local-variable 'pcomplete-parse-arguments-function) 'ledger-parse-arguments) @@ -475,41 +475,41 @@ dropped." (defun ledger-display-balance () (let ((buffer ledger-buf) - (account ledger-acct)) + (account ledger-acct)) (with-temp-buffer (let ((exit-code (ledger-run-ledger buffer "-C" "balance" account))) - (if (/= 0 exit-code) - (message "Error determining cleared balance") - (goto-char (1- (point-max))) - (goto-char (line-beginning-position)) - (delete-horizontal-space) - (message "Cleared balance = %s" - (buffer-substring-no-properties (point) - (line-end-position)))))))) + (if (/= 0 exit-code) + (message "Error determining cleared balance") + (goto-char (1- (point-max))) + (goto-char (line-beginning-position)) + (delete-horizontal-space) + (message "Cleared balance = %s" + (buffer-substring-no-properties (point) + (line-end-position)))))))) (defun ledger-reconcile-toggle () (interactive) (let ((where (get-text-property (point) 'where)) - (account ledger-acct) - (inhibit-read-only t) - cleared) + (account ledger-acct) + (inhibit-read-only t) + cleared) (when (or (equal (car where) "<stdin>") (equal (car where) "/dev/stdin")) (with-current-buffer ledger-buf - (goto-char (cdr where)) - (setq cleared (ledger-toggle-current 'pending))) + (goto-char (cdr where)) + (setq cleared (ledger-toggle-current 'pending))) (if cleared - (add-text-properties (line-beginning-position) - (line-end-position) - (list 'face 'bold)) - (remove-text-properties (line-beginning-position) - (line-end-position) - (list 'face)))) + (add-text-properties (line-beginning-position) + (line-end-position) + (list 'face 'bold)) + (remove-text-properties (line-beginning-position) + (line-end-position) + (list 'face)))) (forward-line))) (defun ledger-reconcile-refresh () (interactive) (let ((inhibit-read-only t) - (line (count-lines (point-min) (point)))) + (line (count-lines (point-min) (point)))) (erase-buffer) (ledger-do-reconcile) (set-buffer-modified-p t) @@ -519,9 +519,9 @@ dropped." (defun ledger-reconcile-refresh-after-save () (let ((buf (get-buffer "*Reconcile*"))) (if buf - (with-current-buffer buf - (ledger-reconcile-refresh) - (set-buffer-modified-p nil))))) + (with-current-buffer buf + (ledger-reconcile-refresh) + (set-buffer-modified-p nil))))) (defun ledger-reconcile-add () (interactive) @@ -534,12 +534,12 @@ dropped." (let ((where (get-text-property (point) 'where))) (when (or (equal (car where) "<stdin>") (equal (car where) "/dev/stdin")) (with-current-buffer ledger-buf - (goto-char (cdr where)) - (ledger-delete-current-entry)) + (goto-char (cdr where)) + (ledger-delete-current-entry)) (let ((inhibit-read-only t)) - (goto-char (line-beginning-position)) - (delete-region (point) (1+ (line-end-position))) - (set-buffer-modified-p t))))) + (goto-char (line-beginning-position)) + (delete-region (point) (1+ (line-end-position))) + (set-buffer-modified-p t))))) (defun ledger-reconcile-visit () (interactive) @@ -565,53 +565,53 @@ dropped." (goto-char (point-min)) (while (not (eobp)) (let ((where (get-text-property (point) 'where)) - (face (get-text-property (point) 'face))) - (if (and (eq face 'bold) - (or (equal (car where) "<stdin>") (equal (car where) "/dev/stdin"))) - (with-current-buffer ledger-buf - (goto-char (cdr where)) - (ledger-toggle-current 'cleared)))) + (face (get-text-property (point) 'face))) + (if (and (eq face 'bold) + (or (equal (car where) "<stdin>") (equal (car where) "/dev/stdin"))) + (with-current-buffer ledger-buf + (goto-char (cdr where)) + (ledger-toggle-current 'cleared)))) (forward-line 1))) (ledger-reconcile-save)) (defun ledger-do-reconcile () (let* ((buf ledger-buf) - (account ledger-acct) - (items - (with-temp-buffer - (let ((exit-code - (ledger-run-ledger buf "--uncleared" "emacs" account))) - (when (= 0 exit-code) - (goto-char (point-min)) - (unless (eobp) - (unless (looking-at "(") - (error (buffer-string))) - (read (current-buffer)))))))) + (account ledger-acct) + (items + (with-temp-buffer + (let ((exit-code + (ledger-run-ledger buf "--uncleared" "emacs" account))) + (when (= 0 exit-code) + (goto-char (point-min)) + (unless (eobp) + (unless (looking-at "(") + (error (buffer-string))) + (read (current-buffer)))))))) (dolist (item items) (let ((index 1)) - (dolist (xact (nthcdr 5 item)) - (let ((beg (point)) - (where - (with-current-buffer buf - (cons - (nth 0 item) - (if ledger-clear-whole-entries - (save-excursion - (goto-line (nth 1 item)) - (point-marker)) - (save-excursion - (goto-line (nth 0 xact)) - (point-marker))))))) - (insert (format "%s %-30s %-25s %15s\n" - (format-time-string "%m/%d" (nth 2 item)) - (nth 4 item) (nth 1 xact) (nth 2 xact))) - (if (nth 3 xact) - (set-text-properties beg (1- (point)) - (list 'face 'bold - 'where where)) - (set-text-properties beg (1- (point)) - (list 'where where)))) - (setq index (1+ index))))) + (dolist (xact (nthcdr 5 item)) + (let ((beg (point)) + (where + (with-current-buffer buf + (cons + (nth 0 item) + (if ledger-clear-whole-entries + (save-excursion + (goto-line (nth 1 item)) + (point-marker)) + (save-excursion + (goto-line (nth 0 xact)) + (point-marker))))))) + (insert (format "%s %-30s %-25s %15s\n" + (format-time-string "%m/%d" (nth 2 item)) + (nth 4 item) (nth 1 xact) (nth 2 xact))) + (if (nth 3 xact) + (set-text-properties beg (1- (point)) + (list 'face 'bold + 'where where)) + (set-text-properties beg (1- (point)) + (list 'where where)))) + (setq index (1+ index))))) (goto-char (point-min)) (set-buffer-modified-p nil) (toggle-read-only t))) @@ -619,12 +619,12 @@ dropped." (defun ledger-reconcile (account) (interactive "sAccount to reconcile: ") (let ((buf (current-buffer)) - (rbuf (get-buffer "*Reconcile*"))) + (rbuf (get-buffer "*Reconcile*"))) (if rbuf - (kill-buffer rbuf)) + (kill-buffer rbuf)) (add-hook 'after-save-hook 'ledger-reconcile-refresh-after-save) (with-current-buffer - (pop-to-buffer (get-buffer-create "*Reconcile*")) + (pop-to-buffer (get-buffer-create "*Reconcile*")) (ledger-reconcile-mode) (set (make-local-variable 'ledger-buf) buf) (set (make-local-variable 'ledger-acct) account) @@ -681,24 +681,24 @@ dropped." Assumes point is at beginning of line, and the pos argument specifies where the \"users\" point was." (let ((linfo (assoc line-type ledger-line-config)) - found field fields) + found field fields) (dolist (re-info (nth 1 linfo)) (let ((re (nth 0 re-info)) - (names (nth 1 re-info))) - (unless found - (when (looking-at re) - (setq found t) - (dotimes (i (length names)) - (when (nth i names) - (setq fields (append fields - (list - (list (nth i names) - (match-string-no-properties (1+ i)) - (match-beginning (1+ i)))))))) - (dolist (f fields) - (and (nth 1 f) - (>= pos (nth 2 f)) - (setq field (nth 0 f)))))))) + (names (nth 1 re-info))) + (unless found + (when (looking-at re) + (setq found t) + (dotimes (i (length names)) + (when (nth i names) + (setq fields (append fields + (list + (list (nth i names) + (match-string-no-properties (1+ i)) + (match-beginning (1+ i)))))))) + (dolist (f fields) + (and (nth 1 f) + (>= pos (nth 2 f)) + (setq field (nth 0 f)))))))) (list line-type field fields))) (defun ledger-context-at-point () @@ -711,40 +711,40 @@ the fields in the line in a association list." (save-excursion (beginning-of-line) (let ((first-char (char-after))) - (cond ((equal (point) (line-end-position)) - '(empty-line nil nil)) - ((memq first-char '(?\ ?\t)) - (ledger-extract-context-info 'acct-transaction pos)) - ((memq first-char '(?0 ?1 ?2 ?3 ?4 ?5 ?6 ?7 ?8 ?9)) - (ledger-extract-context-info 'entry pos)) - ((equal first-char ?\=) - '(automated-entry nil nil)) - ((equal first-char ?\~) - '(period-entry nil nil)) - ((equal first-char ?\!) - '(command-directive)) - ((equal first-char ?\;) - '(comment nil nil)) - ((equal first-char ?Y) - '(default-year nil nil)) - ((equal first-char ?P) - '(commodity-price nil nil)) - ((equal first-char ?N) - '(price-ignored-commodity nil nil)) - ((equal first-char ?D) - '(default-commodity nil nil)) - ((equal first-char ?C) - '(commodity-conversion nil nil)) - ((equal first-char ?i) - '(timeclock-i nil nil)) - ((equal first-char ?o) - '(timeclock-o nil nil)) - ((equal first-char ?b) - '(timeclock-b nil nil)) - ((equal first-char ?h) - '(timeclock-h nil nil)) - (t - '(unknown nil nil))))))) + (cond ((equal (point) (line-end-position)) + '(empty-line nil nil)) + ((memq first-char '(?\ ?\t)) + (ledger-extract-context-info 'acct-transaction pos)) + ((memq first-char '(?0 ?1 ?2 ?3 ?4 ?5 ?6 ?7 ?8 ?9)) + (ledger-extract-context-info 'entry pos)) + ((equal first-char ?\=) + '(automated-entry nil nil)) + ((equal first-char ?\~) + '(period-entry nil nil)) + ((equal first-char ?\!) + '(command-directive)) + ((equal first-char ?\;) + '(comment nil nil)) + ((equal first-char ?Y) + '(default-year nil nil)) + ((equal first-char ?P) + '(commodity-price nil nil)) + ((equal first-char ?N) + '(price-ignored-commodity nil nil)) + ((equal first-char ?D) + '(default-commodity nil nil)) + ((equal first-char ?C) + '(commodity-conversion nil nil)) + ((equal first-char ?i) + '(timeclock-i nil nil)) + ((equal first-char ?o) + '(timeclock-o nil nil)) + ((equal first-char ?b) + '(timeclock-b nil nil)) + ((equal first-char ?h) + '(timeclock-h nil nil)) + (t + '(unknown nil nil))))))) (defun ledger-context-other-line (offset) "Return a list describing context of line offset for existing position. @@ -754,8 +754,8 @@ specified line, returns nil." (save-excursion (let ((left (forward-line offset))) (if (not (equal left 0)) - nil - (ledger-context-at-point))))) + nil + (ledger-context-at-point))))) (defun ledger-context-line-type (context-info) (nth 0 context-info)) @@ -792,8 +792,8 @@ specified line, returns nil." (setq i (- i 1))) (let ((context-info (ledger-context-other-line i))) (if (eq (ledger-context-line-type context-info) 'entry) - (ledger-context-field-value context-info 'payee) - nil)))) + (ledger-context-field-value context-info 'payee) + nil)))) ;; Ledger report mode @@ -832,8 +832,8 @@ specified line, returns nil." The empty string and unknown names are allowed." (completing-read "Report name: " - ledger-reports nil nil nil - 'ledger-report-name-prompt-history nil)) + ledger-reports nil nil nil + 'ledger-report-name-prompt-history nil)) (defun ledger-report (report-name edit) "Run a user-specified report from `ledger-reports'. @@ -852,18 +852,18 @@ used to generate the buffer, navigating the buffer, etc." (interactive (progn (when (and (buffer-modified-p) - (y-or-n-p "Buffer modified, save it? ")) + (y-or-n-p "Buffer modified, save it? ")) (save-buffer)) (let ((rname (ledger-report-read-name)) - (edit (not (null current-prefix-arg)))) + (edit (not (null current-prefix-arg)))) (list rname edit)))) (let ((buf (current-buffer)) - (rbuf (get-buffer ledger-report-buffer-name)) - (wcfg (current-window-configuration))) + (rbuf (get-buffer ledger-report-buffer-name)) + (wcfg (current-window-configuration))) (if rbuf - (kill-buffer rbuf)) + (kill-buffer rbuf)) (with-current-buffer - (pop-to-buffer (get-buffer-create ledger-report-buffer-name)) + (pop-to-buffer (get-buffer-create ledger-report-buffer-name)) (ledger-report-mode) (set (make-local-variable 'ledger-buf) buf) (set (make-local-variable 'ledger-report-name) report-name) @@ -896,8 +896,8 @@ If name exists, returns the object naming the report, otherwise returns nil." (defun ledger-report-read-command (report-cmd) "Read the command line to create a report." (read-from-minibuffer "Report command line: " - (if (null report-cmd) "ledger " report-cmd) - nil nil 'ledger-report-cmd-prompt-history)) + (if (null report-cmd) "ledger " report-cmd) + nil nil 'ledger-report-cmd-prompt-history)) (defun ledger-report-ledger-file-format-specifier () "Substitute the full path to master or current ledger file @@ -909,9 +909,9 @@ otherwise the current buffer file is used." (defun ledger-read-string-with-default (prompt default) (let ((default-prompt (concat prompt - (if default - (concat " (" default "): ") - ": ")))) + (if default + (concat " (" default "): ") + ": ")))) (read-string default-prompt nil nil default))) (defun ledger-report-payee-format-specifier () @@ -935,26 +935,26 @@ the default." ;; It is intended completion should be available on existing account ;; names, but it remains to be implemented. (let* ((context (ledger-context-at-point)) - (default - (if (eq (ledger-context-line-type context) 'acct-transaction) - (regexp-quote (ledger-context-field-value context 'account)) - nil))) + (default + (if (eq (ledger-context-line-type context) 'acct-transaction) + (regexp-quote (ledger-context-field-value context 'account)) + nil))) (ledger-read-string-with-default "Account" default))) (defun ledger-report-expand-format-specifiers (report-cmd) (let ((expanded-cmd report-cmd)) (while (string-match "%(\\([^)]*\\))" expanded-cmd) (let* ((specifier (match-string 1 expanded-cmd)) - (f (cdr (assoc specifier ledger-report-format-specifiers)))) - (if f - (setq expanded-cmd (replace-match - (save-match-data - (with-current-buffer ledger-buf - (shell-quote-argument (funcall f)))) - t t expanded-cmd)) - (progn - (set-window-configuration ledger-original-window-cfg) - (error "Invalid ledger report format specifier '%s'" specifier))))) + (f (cdr (assoc specifier ledger-report-format-specifiers)))) + (if f + (setq expanded-cmd (replace-match + (save-match-data + (with-current-buffer ledger-buf + (shell-quote-argument (funcall f)))) + t t expanded-cmd)) + (progn + (set-window-configuration ledger-original-window-cfg) + (error "Invalid ledger report format specifier '%s'" specifier))))) expanded-cmd)) (defun ledger-report-cmd (report-name edit) @@ -966,18 +966,18 @@ the default." (setq report-cmd (ledger-report-expand-format-specifiers report-cmd)) (set (make-local-variable 'ledger-report-cmd) report-cmd) (or (string-empty-p report-name) - (ledger-report-name-exists report-name) - (ledger-reports-add report-name report-cmd) - (ledger-reports-custom-save)) + (ledger-report-name-exists report-name) + (ledger-reports-add report-name report-cmd) + (ledger-reports-custom-save)) report-cmd)) (defun ledger-do-report (cmd) "Run a report command line." (goto-char (point-min)) (insert (format "Report: %s\n" ledger-report-name) - (format "Command: %s\n" cmd) - (make-string (- (window-width) 1) ?=) - "\n") + (format "Command: %s\n" cmd) + (make-string (- (window-width) 1) ?=) + "\n") (shell-command cmd t nil)) (defun ledger-report-goto () @@ -985,7 +985,7 @@ the default." (interactive) (let ((rbuf (get-buffer ledger-report-buffer-name))) (if (not rbuf) - (error "There is no ledger report buffer")) + (error "There is no ledger report buffer")) (pop-to-buffer rbuf) (shrink-window-if-larger-than-buffer))) @@ -1021,7 +1021,7 @@ the default." (let ((name "")) (while (string-empty-p name) (setq name (read-from-minibuffer "Report name: " nil nil nil - 'ledger-report-name-prompt-history))) + 'ledger-report-name-prompt-history))) name)) (defun ledger-report-save () @@ -1034,15 +1034,15 @@ the default." (while (setq existing-name (ledger-report-name-exists ledger-report-name)) (cond ((y-or-n-p (format "Overwrite existing report named '%s' " - ledger-report-name)) - (when (string-equal - ledger-report-cmd - (car (cdr (assq existing-name ledger-reports)))) - (error "Current command is identical to existing saved one")) - (setq ledger-reports - (assq-delete-all existing-name ledger-reports))) - (t - (setq ledger-report-name (ledger-report-read-new-name))))) + ledger-report-name)) + (when (string-equal + ledger-report-cmd + (car (cdr (assq existing-name ledger-reports)))) + (error "Current command is identical to existing saved one")) + (setq ledger-reports + (assq-delete-all existing-name ledger-reports))) + (t + (setq ledger-report-name (ledger-report-read-new-name))))) (ledger-reports-add ledger-report-name ledger-report-cmd) (ledger-reports-custom-save))) @@ -1053,46 +1053,46 @@ the default." (let ((here (point))) (goto-char (line-beginning-position)) (cond ((looking-at "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.+?)\\)?\\s-+") - (goto-char (match-end 0)) - 'entry) - ((looking-at "^\\s-+\\([*!]\\s-+\\)?[[(]?\\(.\\)") - (goto-char (match-beginning 2)) - 'transaction) - ((looking-at "^\\(sun\\|mon\\|tue\\|wed\\|thu\\|fri\\|sat\\)\\s-+") - (goto-char (match-end 0)) - 'entry) - (t - (ignore (goto-char here)))))) + (goto-char (match-end 0)) + 'entry) + ((looking-at "^\\s-+\\([*!]\\s-+\\)?[[(]?\\(.\\)") + (goto-char (match-beginning 2)) + 'transaction) + ((looking-at "^\\(sun\\|mon\\|tue\\|wed\\|thu\\|fri\\|sat\\)\\s-+") + (goto-char (match-end 0)) + 'entry) + (t + (ignore (goto-char here)))))) (defun ledger-parse-arguments () "Parse whitespace separated arguments in the current region." (let* ((info (save-excursion - (cons (ledger-thing-at-point) (point)))) - (begin (cdr info)) - (end (point)) - begins args) + (cons (ledger-thing-at-point) (point)))) + (begin (cdr info)) + (end (point)) + begins args) (save-excursion (goto-char begin) (when (< (point) end) - (skip-chars-forward " \t\n") - (setq begins (cons (point) begins)) - (setq args (cons (buffer-substring-no-properties - (car begins) end) - args))) + (skip-chars-forward " \t\n") + (setq begins (cons (point) begins)) + (setq args (cons (buffer-substring-no-properties + (car begins) end) + args))) (cons (reverse args) (reverse begins))))) (defun ledger-entries () (let ((origin (point)) - entries-list) + entries-list) (save-excursion (goto-char (point-min)) (while (re-search-forward - (concat "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.*?)\\)?\\s-+" - "\\(.+?\\)\\(\t\\|\n\\| [ \t]\\)") nil t) - (unless (and (>= origin (match-beginning 0)) - (< origin (match-end 0))) - (setq entries-list (cons (match-string-no-properties 3) - entries-list))))) + (concat "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.*?)\\)?\\s-+" + "\\(.+?\\)\\(\t\\|\n\\| [ \t]\\)") nil t) + (unless (and (>= origin (match-beginning 0)) + (< origin (match-end 0))) + (setq entries-list (cons (match-string-no-properties 3) + entries-list))))) (pcomplete-uniqify-list (nreverse entries-list)))) (defvar ledger-account-tree nil) @@ -1103,100 +1103,100 @@ the default." (setq ledger-account-tree (list t)) (goto-char (point-min)) (while (re-search-forward - "^[ \t]+\\([*!]\\s-+\\)?[[(]?\\(.+?\\)\\(\t\\|\n\\| [ \t]\\)" nil t) - (unless (and (>= origin (match-beginning 0)) - (< origin (match-end 0))) - (setq account-path (match-string-no-properties 2)) - (setq elements (split-string account-path ":")) - (let ((root ledger-account-tree)) - (while elements - (let ((entry (assoc (car elements) root))) - (if entry - (setq root (cdr entry)) - (setq entry (cons (car elements) (list t))) - (nconc root (list entry)) - (setq root (cdr entry)))) - (setq elements (cdr elements))))))))) + "^[ \t]+\\([*!]\\s-+\\)?[[(]?\\(.+?\\)\\(\t\\|\n\\| [ \t]\\)" nil t) + (unless (and (>= origin (match-beginning 0)) + (< origin (match-end 0))) + (setq account-path (match-string-no-properties 2)) + (setq elements (split-string account-path ":")) + (let ((root ledger-account-tree)) + (while elements + (let ((entry (assoc (car elements) root))) + (if entry + (setq root (cdr entry)) + (setq entry (cons (car elements) (list t))) + (nconc root (list entry)) + (setq root (cdr entry)))) + (setq elements (cdr elements))))))))) (defun ledger-accounts () (ledger-find-accounts) (let* ((current (caar (ledger-parse-arguments))) - (elements (and current (split-string current ":"))) - (root ledger-account-tree) - (prefix nil)) + (elements (and current (split-string current ":"))) + (root ledger-account-tree) + (prefix nil)) (while (cdr elements) (let ((entry (assoc (car elements) root))) - (if entry - (setq prefix (concat prefix (and prefix ":") - (car elements)) - root (cdr entry)) - (setq root nil elements nil))) + (if entry + (setq prefix (concat prefix (and prefix ":") + (car elements)) + root (cdr entry)) + (setq root nil elements nil))) (setq elements (cdr elements))) (and root - (sort - (mapcar (function - (lambda (x) - (let ((term (if prefix - (concat prefix ":" (car x)) - (car x)))) - (if (> (length (cdr x)) 1) - (concat term ":") - term)))) - (cdr root)) - 'string-lessp)))) + (sort + (mapcar (function + (lambda (x) + (let ((term (if prefix + (concat prefix ":" (car x)) + (car x)))) + (if (> (length (cdr x)) 1) + (concat term ":") + term)))) + (cdr root)) + 'string-lessp)))) (defun ledger-complete-at-point () "Do appropriate completion for the thing at point" (interactive) (while (pcomplete-here - (if (eq (save-excursion - (ledger-thing-at-point)) 'entry) - (if (null current-prefix-arg) - (ledger-entries) ; this completes against entry names - (progn - (let ((text (buffer-substring (line-beginning-position) - (line-end-position)))) - (delete-region (line-beginning-position) - (line-end-position)) - (condition-case err - (ledger-add-entry text t) - ((error) - (insert text)))) - (forward-line) - (goto-char (line-end-position)) - (search-backward ";" (line-beginning-position) t) - (skip-chars-backward " \t0123456789.,") - (throw 'pcompleted t))) - (ledger-accounts))))) + (if (eq (save-excursion + (ledger-thing-at-point)) 'entry) + (if (null current-prefix-arg) + (ledger-entries) ; this completes against entry names + (progn + (let ((text (buffer-substring (line-beginning-position) + (line-end-position)))) + (delete-region (line-beginning-position) + (line-end-position)) + (condition-case err + (ledger-add-entry text t) + ((error) + (insert text)))) + (forward-line) + (goto-char (line-end-position)) + (search-backward ";" (line-beginning-position) t) + (skip-chars-backward " \t0123456789.,") + (throw 'pcompleted t))) + (ledger-accounts))))) (defun ledger-fully-complete-entry () "Do appropriate completion for the thing at point" (interactive) (let ((name (caar (ledger-parse-arguments))) - xacts) + xacts) (save-excursion (when (eq 'entry (ledger-thing-at-point)) - (when (re-search-backward - (concat "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.*?)\\)?\\s-+" - (regexp-quote name) "\\(\t\\|\n\\| [ \t]\\)") nil t) - (forward-line) - (while (looking-at "^\\s-+") - (setq xacts (cons (buffer-substring-no-properties - (line-beginning-position) - (line-end-position)) - xacts)) - (forward-line)) - (setq xacts (nreverse xacts))))) + (when (re-search-backward + (concat "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.*?)\\)?\\s-+" + (regexp-quote name) "\\(\t\\|\n\\| [ \t]\\)") nil t) + (forward-line) + (while (looking-at "^\\s-+") + (setq xacts (cons (buffer-substring-no-properties + (line-beginning-position) + (line-end-position)) + xacts)) + (forward-line)) + (setq xacts (nreverse xacts))))) (when xacts (save-excursion - (insert ?\n) - (while xacts - (insert (car xacts) ?\n) - (setq xacts (cdr xacts)))) + (insert ?\n) + (while xacts + (insert (car xacts) ?\n) + (setq xacts (cdr xacts)))) (forward-line) (goto-char (line-end-position)) (if (re-search-backward "\\(\t\\| [ \t]\\)" nil t) - (goto-char (match-end 0)))))) + (goto-char (match-end 0)))))) ;; A sample function for $ users @@ -1205,7 +1205,7 @@ the default." (goto-char (match-beginning 0)) (skip-syntax-forward " ") (- (or (match-end 4) - (match-end 3)) (point)))) + (match-end 3)) (point)))) (defun ledger-align-amounts (&optional column) "Align amounts in the current region. @@ -1215,24 +1215,24 @@ This is done so that the last digit falls in COLUMN, which defaults to 52." (setq column 52)) (save-excursion (let* ((mark-first (< (mark) (point))) - (begin (if mark-first (mark) (point))) - (end (if mark-first (point-marker) (mark-marker))) - offset) + (begin (if mark-first (mark) (point))) + (end (if mark-first (point-marker) (mark-marker))) + offset) (goto-char begin) (while (setq offset (ledger-next-amount end)) - (let ((col (current-column)) - (target-col (- column offset)) - adjust) - (setq adjust (- target-col col)) - (if (< col target-col) - (insert (make-string (- target-col col) ? )) - (move-to-column target-col) - (if (looking-back " ") - (delete-char (- col target-col)) - (skip-chars-forward "^ \t") - (delete-horizontal-space) - (insert " "))) - (forward-line)))))) + (let ((col (current-column)) + (target-col (- column offset)) + adjust) + (setq adjust (- target-col col)) + (if (< col target-col) + (insert (make-string (- target-col col) ? )) + (move-to-column target-col) + (if (looking-back " ") + (delete-char (- col target-col)) + (skip-chars-forward "^ \t") + (delete-horizontal-space) + (insert " "))) + (forward-line)))))) (defalias 'ledger-align-dollars 'ledger-align-amounts) @@ -1247,14 +1247,14 @@ This is done so that the last digit falls in COLUMN, which defaults to 52." nil (function (lambda () - (if (re-search-forward - (concat "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.*?)\\)?\\s-+" - "\\(.+?\\)\\(\t\\|\n\\| [ \t]\\)") nil t) - (goto-char (match-beginning 0)) - (goto-char (point-max))))) + (if (re-search-forward + (concat "^[0-9/.=-]+\\(\\s-+\\*\\)?\\(\\s-+(.*?)\\)?\\s-+" + "\\(.+?\\)\\(\t\\|\n\\| [ \t]\\)") nil t) + (goto-char (match-beginning 0)) + (goto-char (point-max))))) (function (lambda () - (forward-paragraph)))))) + (forward-paragraph)))))) ;; General helper functions @@ -1269,13 +1269,13 @@ This is done so that the last digit falls in COLUMN, which defaults to 52." (t (let ((buf (current-buffer))) (with-current-buffer buffer - (let ((coding-system-for-write 'utf-8) - (coding-system-for-read 'utf-8)) - (apply #'call-process-region - (append (list (point-min) (point-max) - ledger-binary-path ledger-delete-after - buf nil "-f" "-") - args)))))))) + (let ((coding-system-for-write 'utf-8) + (coding-system-for-read 'utf-8)) + (apply #'call-process-region + (append (list (point-min) (point-max) + ledger-binary-path ledger-delete-after + buf nil "-f" "-") + args)))))))) (defun ledger-run-ledger-and-delete (buffer &rest args) (let ((ledger-delete-after t)) diff --git a/lisp/timeclock.el b/lisp/timeclock.el index 03159e94..2cafa8eb 100644 --- a/lisp/timeclock.el +++ b/lisp/timeclock.el @@ -135,10 +135,10 @@ that day has a length that is different from the norm." "*If non-nil, ask if the user wants to clock out before exiting Emacs. This variable only has effect if set with \\[customize]." :set (lambda (symbol value) - (if value - (add-hook 'kill-emacs-query-functions 'timeclock-query-out) - (remove-hook 'kill-emacs-query-functions 'timeclock-query-out)) - (setq timeclock-ask-before-exiting value)) + (if value + (add-hook 'kill-emacs-query-functions 'timeclock-query-out) + (remove-hook 'kill-emacs-query-functions 'timeclock-query-out)) + (setq timeclock-ask-before-exiting value)) :type 'boolean :group 'timeclock) @@ -160,27 +160,27 @@ while timeclock information is being displayed in the modeline has no effect. You should call the function `timeclock-modeline-display' with a positive argument to force an update." :set (lambda (symbol value) - (let ((currently-displaying - (and (boundp 'timeclock-modeline-display) - timeclock-modeline-display))) - ;; if we're changing to the state that - ;; `timeclock-modeline-display' is already using, don't - ;; bother toggling it. This happens on the initial loading - ;; of timeclock.el. - (if (and currently-displaying - (or (and value - (boundp 'display-time-hook) - (memq 'timeclock-update-modeline - display-time-hook)) - (and (not value) - timeclock-update-timer))) - (setq currently-displaying nil)) - (and currently-displaying - (set-variable 'timeclock-modeline-display nil)) - (setq timeclock-use-display-time value) - (and currently-displaying - (set-variable 'timeclock-modeline-display t)) - timeclock-use-display-time)) + (let ((currently-displaying + (and (boundp 'timeclock-modeline-display) + timeclock-modeline-display))) + ;; if we're changing to the state that + ;; `timeclock-modeline-display' is already using, don't + ;; bother toggling it. This happens on the initial loading + ;; of timeclock.el. + (if (and currently-displaying + (or (and value + (boundp 'display-time-hook) + (memq 'timeclock-update-modeline + display-time-hook)) + (and (not value) + timeclock-update-timer))) + (setq currently-displaying nil)) + (and currently-displaying + (set-variable 'timeclock-modeline-display nil)) + (setq timeclock-use-display-time value) + (and currently-displaying + (set-variable 'timeclock-modeline-display t)) + timeclock-use-display-time)) :type 'boolean :group 'timeclock :require 'time) @@ -281,39 +281,39 @@ display (non-nil means on)." (setq timeclock-mode-string "") (or global-mode-string (setq global-mode-string '(""))) (let ((on-p (if arg - (> (prefix-numeric-value arg) 0) - (not timeclock-modeline-display)))) + (> (prefix-numeric-value arg) 0) + (not timeclock-modeline-display)))) (if on-p - (progn - (or (memq 'timeclock-mode-string global-mode-string) - (setq global-mode-string - (append global-mode-string '(timeclock-mode-string)))) - (unless (memq 'timeclock-update-modeline timeclock-event-hook) - (add-hook 'timeclock-event-hook 'timeclock-update-modeline)) - (when timeclock-update-timer - (cancel-timer timeclock-update-timer) - (setq timeclock-update-timer nil)) - (if (boundp 'display-time-hook) - (remove-hook 'display-time-hook 'timeclock-update-modeline)) - (if timeclock-use-display-time - (progn - ;; Update immediately so there is a visible change - ;; on calling this function. - (if display-time-mode (timeclock-update-modeline) - (message "Activate `display-time-mode' to see \ + (progn + (or (memq 'timeclock-mode-string global-mode-string) + (setq global-mode-string + (append global-mode-string '(timeclock-mode-string)))) + (unless (memq 'timeclock-update-modeline timeclock-event-hook) + (add-hook 'timeclock-event-hook 'timeclock-update-modeline)) + (when timeclock-update-timer + (cancel-timer timeclock-update-timer) + (setq timeclock-update-timer nil)) + (if (boundp 'display-time-hook) + (remove-hook 'display-time-hook 'timeclock-update-modeline)) + (if timeclock-use-display-time + (progn + ;; Update immediately so there is a visible change + ;; on calling this function. + (if display-time-mode (timeclock-update-modeline) + (message "Activate `display-time-mode' to see \ timeclock information")) - (add-hook 'display-time-hook 'timeclock-update-modeline)) - (setq timeclock-update-timer - (run-at-time nil 60 'timeclock-update-modeline)))) + (add-hook 'display-time-hook 'timeclock-update-modeline)) + (setq timeclock-update-timer + (run-at-time nil 60 'timeclock-update-modeline)))) (setq global-mode-string - (delq 'timeclock-mode-string global-mode-string)) + (delq 'timeclock-mode-string global-mode-string)) (remove-hook 'timeclock-event-hook 'timeclock-update-modeline) (if (boundp 'display-time-hook) - (remove-hook 'display-time-hook - 'timeclock-update-modeline)) + (remove-hook 'display-time-hook + 'timeclock-update-modeline)) (when timeclock-update-timer - (cancel-timer timeclock-update-timer) - (setq timeclock-update-timer nil))) + (cancel-timer timeclock-update-timer) + (setq timeclock-update-timer nil))) (force-mode-line-update) (setq timeclock-modeline-display on-p))) @@ -323,8 +323,8 @@ timeclock information")) "Toggle modeline display of time remaining. You must modify via \\[customize] for this variable to have an effect." :set (lambda (symbol value) - (setq timeclock-modeline-display - (timeclock-modeline-display (or value 0)))) + (setq timeclock-modeline-display + (timeclock-modeline-display (or value 0)))) :type 'boolean :group 'timeclock :require 'timeclock) @@ -349,34 +349,34 @@ interactively -- call the function `timeclock-get-project-function' to discover the name of the project." (interactive (list (and current-prefix-arg - (if (numberp current-prefix-arg) - (* current-prefix-arg 60 60) - 0)))) + (if (numberp current-prefix-arg) + (* current-prefix-arg 60 60) + 0)))) (if (equal (car timeclock-last-event) "i") (error "You've already clocked in!") (unless timeclock-last-event (timeclock-reread-log)) ;; Either no log file, or day has rolled over. (unless (and timeclock-last-event - (equal (timeclock-time-to-date - (cadr timeclock-last-event)) - (timeclock-time-to-date (current-time)))) + (equal (timeclock-time-to-date + (cadr timeclock-last-event)) + (timeclock-time-to-date (current-time)))) (let ((workday (or (and (numberp arg) arg) - (and arg 0) - (and timeclock-get-workday-function - (funcall timeclock-get-workday-function)) - timeclock-workday))) - (run-hooks 'timeclock-first-in-hook) - ;; settle the discrepancy for the new day - (setq timeclock-discrepancy - (- (or timeclock-discrepancy 0) workday)) - (if (not (= workday timeclock-workday)) - (timeclock-log "h" (and (numberp arg) - (number-to-string arg)))))) + (and arg 0) + (and timeclock-get-workday-function + (funcall timeclock-get-workday-function)) + timeclock-workday))) + (run-hooks 'timeclock-first-in-hook) + ;; settle the discrepancy for the new day + (setq timeclock-discrepancy + (- (or timeclock-discrepancy 0) workday)) + (if (not (= workday timeclock-workday)) + (timeclock-log "h" (and (numberp arg) + (number-to-string arg)))))) (timeclock-log "i" (or project - (and timeclock-get-project-function - (or find-project (interactive-p)) - (funcall timeclock-get-project-function)))) + (and timeclock-get-project-function + (or find-project (interactive-p)) + (funcall timeclock-get-project-function)))) (run-hooks 'timeclock-in-hook))) ;;;###autoload @@ -397,12 +397,12 @@ discover the reason." (timeclock-log (if arg "O" "o") (or reason - (and timeclock-get-reason-function - (or find-reason (interactive-p)) - (funcall timeclock-get-reason-function)))) + (and timeclock-get-reason-function + (or find-reason (interactive-p)) + (funcall timeclock-get-reason-function)))) (run-hooks 'timeclock-out-hook) (if arg - (run-hooks 'timeclock-done-hook)))) + (run-hooks 'timeclock-done-hook)))) ;; Should today-only be removed in favour of timeclock-relative? - gm (defsubst timeclock-workday-remaining (&optional today-only) @@ -412,8 +412,8 @@ If TODAY-ONLY is non-nil, the value returned will be relative only to the time worked today, and not to past time." (let ((discrep (timeclock-find-discrep))) (if discrep - (- (if today-only (cadr discrep) - (car discrep))) + (- (if today-only (cadr discrep) + (car discrep))) 0.0))) ;;;###autoload @@ -424,24 +424,24 @@ If TODAY-ONLY is non-nil, the display will be relative only to time worked today, ignoring the time worked on previous days." (interactive "P") (let ((remainder (timeclock-workday-remaining)) ; today-only? - (last-in (equal (car timeclock-last-event) "i")) - status) + (last-in (equal (car timeclock-last-event) "i")) + status) (setq status - (format "Currently %s since %s (%s), %s %s, leave at %s" - (if last-in "IN" "OUT") - (if show-seconds - (format-time-string "%-I:%M:%S %p" - (nth 1 timeclock-last-event)) - (format-time-string "%-I:%M %p" - (nth 1 timeclock-last-event))) - (or (nth 2 timeclock-last-event) - (if last-in "**UNKNOWN**" "workday over")) - (timeclock-seconds-to-string remainder show-seconds t) - (if (> remainder 0) - "remaining" "over") - (timeclock-when-to-leave-string show-seconds today-only))) + (format "Currently %s since %s (%s), %s %s, leave at %s" + (if last-in "IN" "OUT") + (if show-seconds + (format-time-string "%-I:%M:%S %p" + (nth 1 timeclock-last-event)) + (format-time-string "%-I:%M %p" + (nth 1 timeclock-last-event))) + (or (nth 2 timeclock-last-event) + (if last-in "**UNKNOWN**" "workday over")) + (timeclock-seconds-to-string remainder show-seconds t) + (if (> remainder 0) + "remaining" "over") + (timeclock-when-to-leave-string show-seconds today-only))) (if (interactive-p) - (message status) + (message status) status))) ;;;###autoload @@ -477,7 +477,7 @@ Returns the new value of `timeclock-discrepancy'." timeclock-discrepancy) (defun timeclock-seconds-to-string (seconds &optional show-seconds - reverse-leader) + reverse-leader) "Convert SECONDS into a compact time string. If SHOW-SECONDS is non-nil, make the resolution of the return string include the second count. If REVERSE-LEADER is non-nil, it means to @@ -486,14 +486,14 @@ This is used when negative time values have an inverted meaning (such as with time remaining, where negative time really means overtime)." (if show-seconds (format "%s%d:%02d:%02d" - (if (< seconds 0) (if reverse-leader "+" "-") "") - (truncate (/ (abs seconds) 60 60)) - (% (truncate (/ (abs seconds) 60)) 60) - (% (truncate (abs seconds)) 60)) + (if (< seconds 0) (if reverse-leader "+" "-") "") + (truncate (/ (abs seconds) 60 60)) + (% (truncate (/ (abs seconds) 60)) 60) + (% (truncate (abs seconds)) 60)) (format "%s%d:%02d" - (if (< seconds 0) (if reverse-leader "+" "-") "") - (truncate (/ (abs seconds) 60 60)) - (% (truncate (/ (abs seconds) 60)) 60)))) + (if (< seconds 0) (if reverse-leader "+" "-") "") + (truncate (/ (abs seconds) 60 60)) + (% (truncate (/ (abs seconds) 60)) 60)))) (defsubst timeclock-currently-in-p () "Return non-nil if the user is currently clocked in." @@ -501,7 +501,7 @@ as with time remaining, where negative time really means overtime)." ;;;###autoload (defun timeclock-workday-remaining-string (&optional show-seconds - today-only) + today-only) "Return a string representing the amount of time left today. Display second resolution if SHOW-SECONDS is non-nil. If TODAY-ONLY is non-nil, the display will be relative only to time worked today. @@ -509,10 +509,10 @@ See `timeclock-relative' for more information about the meaning of \"relative to today\"." (interactive) (let ((string (timeclock-seconds-to-string - (timeclock-workday-remaining today-only) - show-seconds t))) + (timeclock-workday-remaining today-only) + show-seconds t))) (if (interactive-p) - (message string) + (message string) string))) (defsubst timeclock-workday-elapsed () @@ -522,7 +522,7 @@ time worked. The default is to return only the time that has elapsed so far today." (let ((discrep (timeclock-find-discrep))) (if discrep - (nth 2 discrep) + (nth 2 discrep) 0.0))) ;;;###autoload @@ -532,9 +532,9 @@ Display seconds resolution if SHOW-SECONDS is non-nil. If RELATIVE is non-nil, the amount returned will be relative to past time worked." (interactive) (let ((string (timeclock-seconds-to-string (timeclock-workday-elapsed) - show-seconds))) + show-seconds))) (if (interactive-p) - (message string) + (message string) string))) (defsubst timeclock-time-to-seconds (time) @@ -546,8 +546,8 @@ non-nil, the amount returned will be relative to past time worked." (defsubst timeclock-seconds-to-time (seconds) "Convert SECONDS (a floating point number) to an Emacs time structure." (list (floor seconds 65536) - (floor (mod seconds 65536)) - (floor (* (- seconds (ffloor seconds)) 1000000)))) + (floor (mod seconds 65536)) + (floor (* (- seconds (ffloor seconds)) 1000000)))) ;; Should today-only be removed in favour of timeclock-relative? - gm (defsubst timeclock-when-to-leave (&optional today-only) @@ -557,15 +557,15 @@ the time worked today, and not to past time." (timeclock-seconds-to-time (- (timeclock-time-to-seconds (current-time)) (let ((discrep (timeclock-find-discrep))) - (if discrep - (if today-only - (cadr discrep) - (car discrep)) - 0.0))))) + (if discrep + (if today-only + (cadr discrep) + (car discrep)) + 0.0))))) ;;;###autoload (defun timeclock-when-to-leave-string (&optional show-seconds - today-only) + today-only) "Return a string representing the end of today's workday. This string is relative to the value of `timeclock-workday'. If SHOW-SECONDS is non-nil, the value printed/returned will include @@ -574,12 +574,12 @@ relative only to the time worked today, and not to past time." ;; Should today-only be removed in favour of timeclock-relative? - gm (interactive) (let* ((then (timeclock-when-to-leave today-only)) - (string - (if show-seconds - (format-time-string "%-I:%M:%S %p" then) - (format-time-string "%-I:%M %p" then)))) + (string + (if show-seconds + (format-time-string "%-I:%M:%S %p" then) + (format-time-string "%-I:%M %p" then)))) (if (interactive-p) - (message string) + (message string) string))) ;;; Internal Functions: @@ -591,17 +591,17 @@ relative only to the time worked today, and not to past time." "A version of `completing-read' that works on both Emacs and XEmacs." (if (featurep 'xemacs) (let ((str (completing-read prompt alist))) - (if (or (null str) (= (length str) 0)) - default - str)) + (if (or (null str) (= (length str) 0)) + default + str)) (completing-read prompt alist nil nil nil nil default))) (defun timeclock-ask-for-project () "Ask the user for the project they are clocking into." (timeclock-completing-read (format "Clock into which project (default \"%s\"): " - (or timeclock-last-project - (car timeclock-project-list))) + (or timeclock-last-project + (car timeclock-project-list))) (mapcar 'list timeclock-project-list) (or timeclock-last-project (car timeclock-project-list)))) @@ -611,7 +611,7 @@ relative only to the time worked today, and not to past time." (defun timeclock-ask-for-reason () "Ask the user for the reason they are clocking out." (timeclock-completing-read "Reason for clocking out: " - (mapcar 'list timeclock-reason-list))) + (mapcar 'list timeclock-reason-list))) (defun timeclock-update-modeline () "Update the `timeclock-mode-string' displayed in the modeline. @@ -619,22 +619,22 @@ The value of `timeclock-relative' affects the display as described in that variable's documentation." (interactive) (let ((remainder (timeclock-workday-remaining (not timeclock-relative))) - (last-in (equal (car timeclock-last-event) "i"))) + (last-in (equal (car timeclock-last-event) "i"))) (when (and (< remainder 0) - (not (and timeclock-day-over - (equal timeclock-day-over - (timeclock-time-to-date - (current-time)))))) + (not (and timeclock-day-over + (equal timeclock-day-over + (timeclock-time-to-date + (current-time)))))) (setq timeclock-day-over - (timeclock-time-to-date (current-time))) + (timeclock-time-to-date (current-time))) (run-hooks 'timeclock-day-over-hook)) (setq timeclock-mode-string - (propertize - (format " %c%s%c " - (if last-in ?< ?[) - (timeclock-seconds-to-string remainder nil t) - (if last-in ?> ?])) - 'help-echo "timeclock: time remaining")))) + (propertize + (format " %c%s%c " + (if last-in ?< ?[) + (timeclock-seconds-to-string remainder nil t) + (if last-in ?> ?])) + 'help-echo "timeclock: time remaining")))) (put 'timeclock-mode-string 'risky-local-variable t) @@ -645,24 +645,24 @@ being logged for. Normally only \"in\" events specify a project." (with-current-buffer (find-file-noselect timeclock-file) (goto-char (point-max)) (if (not (bolp)) - (insert "\n")) + (insert "\n")) (let ((now (current-time))) (insert code " " - (format-time-string "%Y/%m/%d %H:%M:%S" now) - (or (and project - (stringp project) - (> (length project) 0) - (concat " " project)) - "") - "\n") + (format-time-string "%Y/%m/%d %H:%M:%S" now) + (or (and project + (stringp project) + (> (length project) 0) + (concat " " project)) + "") + "\n") (if (equal (downcase code) "o") - (setq timeclock-last-period - (- (timeclock-time-to-seconds now) - (timeclock-time-to-seconds - (cadr timeclock-last-event))) - timeclock-discrepancy - (+ timeclock-discrepancy - timeclock-last-period))) + (setq timeclock-last-period + (- (timeclock-time-to-seconds now) + (timeclock-time-to-seconds + (cadr timeclock-last-event))) + timeclock-discrepancy + (+ timeclock-discrepancy + timeclock-last-period))) (setq timeclock-last-event (list code now project))) (save-buffer) (run-hooks 'timeclock-event-hook) @@ -670,21 +670,21 @@ being logged for. Normally only \"in\" events specify a project." (defvar timeclock-moment-regexp (concat "\\([bhioO]\\)\\s-+" - "\\([0-9]+\\)/\\([0-9]+\\)/\\([0-9]+\\)\\s-+" - "\\([0-9]+\\):\\([0-9]+\\):\\([0-9]+\\)[ \t]*" "\\([^\n]*\\)")) + "\\([0-9]+\\)/\\([0-9]+\\)/\\([0-9]+\\)\\s-+" + "\\([0-9]+\\):\\([0-9]+\\):\\([0-9]+\\)[ \t]*" "\\([^\n]*\\)")) (defsubst timeclock-read-moment () "Read the moment under point from the timelog." (if (looking-at timeclock-moment-regexp) (let ((code (match-string 1)) - (year (string-to-number (match-string 2))) - (mon (string-to-number (match-string 3))) - (mday (string-to-number (match-string 4))) - (hour (string-to-number (match-string 5))) - (min (string-to-number (match-string 6))) - (sec (string-to-number (match-string 7))) - (project (match-string 8))) - (list code (encode-time sec min hour mday mon year) project)))) + (year (string-to-number (match-string 2))) + (mon (string-to-number (match-string 3))) + (mday (string-to-number (match-string 4))) + (hour (string-to-number (match-string 5))) + (min (string-to-number (match-string 6))) + (sec (string-to-number (match-string 7))) + (project (match-string 8))) + (list code (encode-time sec min hour mday mon year) project)))) (defun timeclock-last-period (&optional moment) "Return the value of the last event period. @@ -695,8 +695,8 @@ This is only provided for coherency when used by `timeclock-discrepancy'." (if (equal (car timeclock-last-event) "i") (- (timeclock-time-to-seconds (or moment (current-time))) - (timeclock-time-to-seconds - (cadr timeclock-last-event))) + (timeclock-time-to-seconds + (cadr timeclock-last-event))) timeclock-last-period)) (defsubst timeclock-entry-length (entry) @@ -741,9 +741,9 @@ This is only provided for coherency when used by (let (projects) (while entry-list (let ((project (timeclock-entry-project (car entry-list)))) - (if projects - (add-to-list 'projects project) - (setq projects (list project)))) + (if projects + (add-to-list 'projects project) + (setq projects (list project)))) (setq entry-list (cdr entry-list))) projects)) @@ -805,11 +805,11 @@ This is only provided for coherency when used by (let (projects) (while day-list (let ((projs (timeclock-day-projects (car day-list)))) - (while projs - (if projects - (add-to-list 'projects (car projs)) - (setq projects (list (car projs)))) - (setq projs (cdr projs)))) + (while projs + (if projects + (add-to-list 'projects (car projs)) + (setq projects (list (car projs)))) + (setq projs (cdr projs)))) (setq day-list (cdr day-list))) projects)) @@ -822,10 +822,10 @@ This is only provided for coherency when used by (defun timeclock-day-list (&optional log-data) (let ((alist (timeclock-day-alist log-data)) - day-list) + day-list) (while alist (setq day-list (cons (cdar alist) day-list) - alist (cdr alist))) + alist (cdr alist))) day-list)) (defsubst timeclock-project-alist (&optional log-data) @@ -963,73 +963,73 @@ lists: See the documentation for the given function if more info is needed." (let* ((log-data (list 0.0 nil nil)) - (now (current-time)) - (todays-date (timeclock-time-to-date now)) - last-date-limited last-date-seconds last-date - (line 0) last beg day entry event) + (now (current-time)) + (todays-date (timeclock-time-to-date now)) + last-date-limited last-date-seconds last-date + (line 0) last beg day entry event) (with-temp-buffer (insert-file-contents (or filename timeclock-file)) (when recent-only - (goto-char (point-max)) - (unless (re-search-backward "^b\\s-+" nil t) - (goto-char (point-min)))) + (goto-char (point-max)) + (unless (re-search-backward "^b\\s-+" nil t) + (goto-char (point-min)))) (while (or (setq event (timeclock-read-moment)) - (and beg (not last) - (setq last t event (list "o" now)))) - (setq line (1+ line)) - (cond ((equal (car event) "b") - (setcar log-data (string-to-number (nth 2 event)))) - ((equal (car event) "h") - (setq last-date-limited (timeclock-time-to-date (cadr event)) - last-date-seconds (* (string-to-number (nth 2 event)) - 3600.0))) - ((equal (car event) "i") - (if beg - (error "Error in format of timelog file, line %d" line) - (setq beg t)) - (setq entry (list (cadr event) nil - (and (> (length (nth 2 event)) 0) - (nth 2 event)))) - (let ((date (timeclock-time-to-date (cadr event)))) - (if (and last-date - (not (equal date last-date))) - (progn - (setcar (cdr log-data) - (cons (cons last-date day) - (cadr log-data))) - (setq day (list (and last-date-limited - last-date-seconds)))) - (unless day - (setq day (list (and last-date-limited - last-date-seconds))))) - (setq last-date date - last-date-limited nil))) - ((equal (downcase (car event)) "o") - (if (not beg) - (error "Error in format of timelog file, line %d" line) - (setq beg nil)) - (setcar (cdr entry) (cadr event)) - (let ((desc (and (> (length (nth 2 event)) 0) - (nth 2 event)))) - (if desc - (nconc entry (list (nth 2 event)))) - (if (equal (car event) "O") - (nconc entry (if desc - (list t) - (list nil t)))) - (nconc day (list entry)) - (setq desc (nth 2 entry)) - (let ((proj (assoc desc (nth 2 log-data)))) - (if (null proj) - (setcar (cddr log-data) - (cons (cons desc (list entry)) - (car (cddr log-data)))) - (nconc (cdr proj) (list entry))))))) - (forward-line)) + (and beg (not last) + (setq last t event (list "o" now)))) + (setq line (1+ line)) + (cond ((equal (car event) "b") + (setcar log-data (string-to-number (nth 2 event)))) + ((equal (car event) "h") + (setq last-date-limited (timeclock-time-to-date (cadr event)) + last-date-seconds (* (string-to-number (nth 2 event)) + 3600.0))) + ((equal (car event) "i") + (if beg + (error "Error in format of timelog file, line %d" line) + (setq beg t)) + (setq entry (list (cadr event) nil + (and (> (length (nth 2 event)) 0) + (nth 2 event)))) + (let ((date (timeclock-time-to-date (cadr event)))) + (if (and last-date + (not (equal date last-date))) + (progn + (setcar (cdr log-data) + (cons (cons last-date day) + (cadr log-data))) + (setq day (list (and last-date-limited + last-date-seconds)))) + (unless day + (setq day (list (and last-date-limited + last-date-seconds))))) + (setq last-date date + last-date-limited nil))) + ((equal (downcase (car event)) "o") + (if (not beg) + (error "Error in format of timelog file, line %d" line) + (setq beg nil)) + (setcar (cdr entry) (cadr event)) + (let ((desc (and (> (length (nth 2 event)) 0) + (nth 2 event)))) + (if desc + (nconc entry (list (nth 2 event)))) + (if (equal (car event) "O") + (nconc entry (if desc + (list t) + (list nil t)))) + (nconc day (list entry)) + (setq desc (nth 2 entry)) + (let ((proj (assoc desc (nth 2 log-data)))) + (if (null proj) + (setcar (cddr log-data) + (cons (cons desc (list entry)) + (car (cddr log-data)))) + (nconc (cdr proj) (list entry))))))) + (forward-line)) (if day - (setcar (cdr log-data) - (cons (cons last-date day) - (cadr log-data)))) + (setcar (cdr log-data) + (cons (cons last-date day) + (cadr log-data)))) log-data))) (defun timeclock-find-discrep () @@ -1050,82 +1050,82 @@ discrepancy, today's discrepancy, and the time worked today." ;; days (cdr days))) ;; total) (let* ((now (current-time)) - (todays-date (timeclock-time-to-date now)) - (first t) (accum 0) (elapsed 0) - event beg last-date avg - last-date-limited last-date-seconds) + (todays-date (timeclock-time-to-date now)) + (first t) (accum 0) (elapsed 0) + event beg last-date avg + last-date-limited last-date-seconds) (unless timeclock-discrepancy (when (file-readable-p timeclock-file) - (setq timeclock-project-list nil - timeclock-last-project nil - timeclock-reason-list nil - timeclock-elapsed 0) - (with-temp-buffer - (insert-file-contents timeclock-file) - (goto-char (point-max)) - (unless (re-search-backward "^b\\s-+" nil t) - (goto-char (point-min))) - (while (setq event (timeclock-read-moment)) - (cond ((equal (car event) "b") - (setq accum (string-to-number (nth 2 event)))) - ((equal (car event) "h") - (setq last-date-limited - (timeclock-time-to-date (cadr event)) - last-date-seconds - (* (string-to-number (nth 2 event)) 3600.0))) - ((equal (car event) "i") - (when (and (nth 2 event) - (> (length (nth 2 event)) 0)) - (add-to-list 'timeclock-project-list (nth 2 event)) - (setq timeclock-last-project (nth 2 event))) - (let ((date (timeclock-time-to-date (cadr event)))) - (if (if last-date - (not (equal date last-date)) - first) - (setq first nil - accum (- accum (if last-date-limited - last-date-seconds - timeclock-workday)))) - (setq last-date date - last-date-limited nil) - (if beg - (error "Error in format of timelog file!") - (setq beg (timeclock-time-to-seconds (cadr event)))))) - ((equal (downcase (car event)) "o") - (if (and (nth 2 event) - (> (length (nth 2 event)) 0)) - (add-to-list 'timeclock-reason-list (nth 2 event))) - (if (not beg) - (error "Error in format of timelog file!") - (setq timeclock-last-period - (- (timeclock-time-to-seconds (cadr event)) beg) - accum (+ timeclock-last-period accum) - beg nil)) - (if (equal last-date todays-date) - (setq timeclock-elapsed - (+ timeclock-last-period timeclock-elapsed))))) - (setq timeclock-last-event event - timeclock-last-event-workday - (if (equal (timeclock-time-to-date now) last-date-limited) - last-date-seconds - timeclock-workday)) - (forward-line)) - (setq timeclock-discrepancy accum)))) + (setq timeclock-project-list nil + timeclock-last-project nil + timeclock-reason-list nil + timeclock-elapsed 0) + (with-temp-buffer + (insert-file-contents timeclock-file) + (goto-char (point-max)) + (unless (re-search-backward "^b\\s-+" nil t) + (goto-char (point-min))) + (while (setq event (timeclock-read-moment)) + (cond ((equal (car event) "b") + (setq accum (string-to-number (nth 2 event)))) + ((equal (car event) "h") + (setq last-date-limited + (timeclock-time-to-date (cadr event)) + last-date-seconds + (* (string-to-number (nth 2 event)) 3600.0))) + ((equal (car event) "i") + (when (and (nth 2 event) + (> (length (nth 2 event)) 0)) + (add-to-list 'timeclock-project-list (nth 2 event)) + (setq timeclock-last-project (nth 2 event))) + (let ((date (timeclock-time-to-date (cadr event)))) + (if (if last-date + (not (equal date last-date)) + first) + (setq first nil + accum (- accum (if last-date-limited + last-date-seconds + timeclock-workday)))) + (setq last-date date + last-date-limited nil) + (if beg + (error "Error in format of timelog file!") + (setq beg (timeclock-time-to-seconds (cadr event)))))) + ((equal (downcase (car event)) "o") + (if (and (nth 2 event) + (> (length (nth 2 event)) 0)) + (add-to-list 'timeclock-reason-list (nth 2 event))) + (if (not beg) + (error "Error in format of timelog file!") + (setq timeclock-last-period + (- (timeclock-time-to-seconds (cadr event)) beg) + accum (+ timeclock-last-period accum) + beg nil)) + (if (equal last-date todays-date) + (setq timeclock-elapsed + (+ timeclock-last-period timeclock-elapsed))))) + (setq timeclock-last-event event + timeclock-last-event-workday + (if (equal (timeclock-time-to-date now) last-date-limited) + last-date-seconds + timeclock-workday)) + (forward-line)) + (setq timeclock-discrepancy accum)))) (unless timeclock-last-event-workday (setq timeclock-last-event-workday timeclock-workday)) (setq accum (or timeclock-discrepancy 0) - elapsed (or timeclock-elapsed elapsed)) + elapsed (or timeclock-elapsed elapsed)) (if timeclock-last-event - (if (equal (car timeclock-last-event) "i") - (let ((last-period (timeclock-last-period now))) - (setq accum (+ accum last-period) - elapsed (+ elapsed last-period))) - (if (not (equal (timeclock-time-to-date - (cadr timeclock-last-event)) - (timeclock-time-to-date now))) - (setq accum (- accum timeclock-last-event-workday))))) + (if (equal (car timeclock-last-event) "i") + (let ((last-period (timeclock-last-period now))) + (setq accum (+ accum last-period) + elapsed (+ elapsed last-period))) + (if (not (equal (timeclock-time-to-date + (cadr timeclock-last-event)) + (timeclock-time-to-date now))) + (setq accum (- accum timeclock-last-event-workday))))) (list accum (- elapsed timeclock-last-event-workday) - elapsed))) + elapsed))) ;;; A reporting function that uses timeclock-log-data @@ -1141,13 +1141,13 @@ If optional argument TIME is non-nil, use that instead of the current time." (defun timeclock-geometric-mean (l) "Compute the geometric mean of the values in the list L." (let ((total 0) - (count 0)) + (count 0)) (while l (setq total (+ total (car l)) - count (1+ count) - l (cdr l))) + count (1+ count) + l (cdr l))) (if (> count 0) - (/ total count) + (/ total count) 0))) (defun timeclock-generate-report (&optional html-p) @@ -1156,71 +1156,71 @@ By default, the report is in plain text, but if the optional argument HTML-P is non-nil, HTML markup is added." (interactive) (let ((log (timeclock-log-data)) - (today (timeclock-day-base))) + (today (timeclock-day-base))) (if html-p (insert "<p>")) (insert "Currently ") (let ((project (nth 2 timeclock-last-event)) - (begin (nth 1 timeclock-last-event)) - done) + (begin (nth 1 timeclock-last-event)) + done) (if (timeclock-currently-in-p) - (insert "IN") - (if (or (null project) (= (length project) 0)) - (progn (insert "Done Working Today") - (setq done t)) - (insert "OUT"))) + (insert "IN") + (if (or (null project) (= (length project) 0)) + (progn (insert "Done Working Today") + (setq done t)) + (insert "OUT"))) (unless done - (insert " since " (format-time-string "%Y/%m/%d %-I:%M %p" begin)) - (if html-p - (insert "<br>\n<b>") - (insert "\n*")) - (if (timeclock-currently-in-p) - (insert "Working on ")) - (if html-p - (insert project "</b><br>\n") - (insert project "*\n")) - (let ((proj-data (cdr (assoc project (timeclock-project-alist log)))) - (two-weeks-ago (timeclock-seconds-to-time - (- (timeclock-time-to-seconds today) - (* 2 7 24 60 60)))) - two-week-len today-len) - (while proj-data - (if (not (time-less-p - (timeclock-entry-begin (car proj-data)) today)) - (setq today-len (timeclock-entry-list-length proj-data) - proj-data nil) - (if (and (null two-week-len) - (not (time-less-p - (timeclock-entry-begin (car proj-data)) - two-weeks-ago))) - (setq two-week-len (timeclock-entry-list-length proj-data))) - (setq proj-data (cdr proj-data)))) - (if (null two-week-len) - (setq two-week-len today-len)) - (if html-p (insert "<p>")) - (if today-len - (insert "\nTime spent on this task today: " - (timeclock-seconds-to-string today-len) - ". In the last two weeks: " - (timeclock-seconds-to-string two-week-len)) - (if two-week-len - (insert "\nTime spent on this task in the last two weeks: " - (timeclock-seconds-to-string two-week-len)))) - (if html-p (insert "<br>")) - (insert "\n" - (timeclock-seconds-to-string (timeclock-workday-elapsed)) - " worked today, " - (timeclock-seconds-to-string (timeclock-workday-remaining)) - " remaining, done at " - (timeclock-when-to-leave-string) "\n"))) + (insert " since " (format-time-string "%Y/%m/%d %-I:%M %p" begin)) + (if html-p + (insert "<br>\n<b>") + (insert "\n*")) + (if (timeclock-currently-in-p) + (insert "Working on ")) + (if html-p + (insert project "</b><br>\n") + (insert project "*\n")) + (let ((proj-data (cdr (assoc project (timeclock-project-alist log)))) + (two-weeks-ago (timeclock-seconds-to-time + (- (timeclock-time-to-seconds today) + (* 2 7 24 60 60)))) + two-week-len today-len) + (while proj-data + (if (not (time-less-p + (timeclock-entry-begin (car proj-data)) today)) + (setq today-len (timeclock-entry-list-length proj-data) + proj-data nil) + (if (and (null two-week-len) + (not (time-less-p + (timeclock-entry-begin (car proj-data)) + two-weeks-ago))) + (setq two-week-len (timeclock-entry-list-length proj-data))) + (setq proj-data (cdr proj-data)))) + (if (null two-week-len) + (setq two-week-len today-len)) + (if html-p (insert "<p>")) + (if today-len + (insert "\nTime spent on this task today: " + (timeclock-seconds-to-string today-len) + ". In the last two weeks: " + (timeclock-seconds-to-string two-week-len)) + (if two-week-len + (insert "\nTime spent on this task in the last two weeks: " + (timeclock-seconds-to-string two-week-len)))) + (if html-p (insert "<br>")) + (insert "\n" + (timeclock-seconds-to-string (timeclock-workday-elapsed)) + " worked today, " + (timeclock-seconds-to-string (timeclock-workday-remaining)) + " remaining, done at " + (timeclock-when-to-leave-string) "\n"))) (if html-p (insert "<p>")) (insert "\nThere have been " - (number-to-string - (length (timeclock-day-alist log))) - " days of activity, starting " - (caar (last (timeclock-day-alist log)))) + (number-to-string + (length (timeclock-day-alist log))) + " days of activity, starting " + (caar (last (timeclock-day-alist log)))) (if html-p (insert "</p>")) (when html-p - (insert "<p> + (insert "<p> <table> <td width=\"25\"><br></td><td> <table border=1 cellpadding=3> @@ -1231,111 +1231,111 @@ HTML-P is non-nil, HTML markup is added." <th>-6 mons</th> <th>-1 year</th> </tr>") - (let* ((day-list (timeclock-day-list)) - (thirty-days-ago (timeclock-seconds-to-time - (- (timeclock-time-to-seconds today) - (* 30 24 60 60)))) - (three-months-ago (timeclock-seconds-to-time - (- (timeclock-time-to-seconds today) - (* 90 24 60 60)))) - (six-months-ago (timeclock-seconds-to-time - (- (timeclock-time-to-seconds today) - (* 180 24 60 60)))) - (one-year-ago (timeclock-seconds-to-time - (- (timeclock-time-to-seconds today) - (* 365 24 60 60)))) - (time-in (vector (list t) (list t) (list t) (list t) (list t))) - (time-out (vector (list t) (list t) (list t) (list t) (list t))) - (breaks (vector (list t) (list t) (list t) (list t) (list t))) - (workday (vector (list t) (list t) (list t) (list t) (list t))) - (lengths (vector '(0 0) thirty-days-ago three-months-ago - six-months-ago one-year-ago))) - ;; collect statistics from complete timelog - (while day-list - (let ((i 0) (l 5)) - (while (< i l) - (unless (time-less-p - (timeclock-day-begin (car day-list)) - (aref lengths i)) - (let ((base (timeclock-time-to-seconds - (timeclock-day-base - (timeclock-day-begin (car day-list)))))) - (nconc (aref time-in i) - (list (- (timeclock-time-to-seconds - (timeclock-day-begin (car day-list))) - base))) - (let ((span (timeclock-day-span (car day-list))) - (len (timeclock-day-length (car day-list))) - (req (timeclock-day-required (car day-list)))) - ;; If the day's actual work length is less than - ;; 70% of its span, then likely the exit time - ;; and break amount are not worthwhile adding to - ;; the statistic - (when (and (> span 0) - (> (/ (float len) (float span)) 0.70)) - (nconc (aref time-out i) - (list (- (timeclock-time-to-seconds - (timeclock-day-end (car day-list))) - base))) - (nconc (aref breaks i) (list (- span len)))) - (if req - (setq len (+ len (- timeclock-workday req)))) - (nconc (aref workday i) (list len))))) - (setq i (1+ i)))) - (setq day-list (cdr day-list))) - ;; average statistics - (let ((i 0) (l 5)) - (while (< i l) - (aset time-in i (timeclock-geometric-mean - (cdr (aref time-in i)))) - (aset time-out i (timeclock-geometric-mean - (cdr (aref time-out i)))) - (aset breaks i (timeclock-geometric-mean - (cdr (aref breaks i)))) - (aset workday i (timeclock-geometric-mean - (cdr (aref workday i)))) - (setq i (1+ i)))) - ;; Output the HTML table - (insert "<tr>\n") - (insert "<td align=\"center\">Time in</td>\n") - (let ((i 0) (l 5)) - (while (< i l) - (insert "<td align=\"right\">" - (timeclock-seconds-to-string (aref time-in i)) - "</td>\n") - (setq i (1+ i)))) - (insert "</tr>\n") - - (insert "<tr>\n") - (insert "<td align=\"center\">Time out</td>\n") - (let ((i 0) (l 5)) - (while (< i l) - (insert "<td align=\"right\">" - (timeclock-seconds-to-string (aref time-out i)) - "</td>\n") - (setq i (1+ i)))) - (insert "</tr>\n") - - (insert "<tr>\n") - (insert "<td align=\"center\">Break</td>\n") - (let ((i 0) (l 5)) - (while (< i l) - (insert "<td align=\"right\">" - (timeclock-seconds-to-string (aref breaks i)) - "</td>\n") - (setq i (1+ i)))) - (insert "</tr>\n") - - (insert "<tr>\n") - (insert "<td align=\"center\">Workday</td>\n") - (let ((i 0) (l 5)) - (while (< i l) - (insert "<td align=\"right\">" - (timeclock-seconds-to-string (aref workday i)) - "</td>\n") - (setq i (1+ i)))) - (insert "</tr>\n")) - (insert "<tfoot> + (let* ((day-list (timeclock-day-list)) + (thirty-days-ago (timeclock-seconds-to-time + (- (timeclock-time-to-seconds today) + (* 30 24 60 60)))) + (three-months-ago (timeclock-seconds-to-time + (- (timeclock-time-to-seconds today) + (* 90 24 60 60)))) + (six-months-ago (timeclock-seconds-to-time + (- (timeclock-time-to-seconds today) + (* 180 24 60 60)))) + (one-year-ago (timeclock-seconds-to-time + (- (timeclock-time-to-seconds today) + (* 365 24 60 60)))) + (time-in (vector (list t) (list t) (list t) (list t) (list t))) + (time-out (vector (list t) (list t) (list t) (list t) (list t))) + (breaks (vector (list t) (list t) (list t) (list t) (list t))) + (workday (vector (list t) (list t) (list t) (list t) (list t))) + (lengths (vector '(0 0) thirty-days-ago three-months-ago + six-months-ago one-year-ago))) + ;; collect statistics from complete timelog + (while day-list + (let ((i 0) (l 5)) + (while (< i l) + (unless (time-less-p + (timeclock-day-begin (car day-list)) + (aref lengths i)) + (let ((base (timeclock-time-to-seconds + (timeclock-day-base + (timeclock-day-begin (car day-list)))))) + (nconc (aref time-in i) + (list (- (timeclock-time-to-seconds + (timeclock-day-begin (car day-list))) + base))) + (let ((span (timeclock-day-span (car day-list))) + (len (timeclock-day-length (car day-list))) + (req (timeclock-day-required (car day-list)))) + ;; If the day's actual work length is less than + ;; 70% of its span, then likely the exit time + ;; and break amount are not worthwhile adding to + ;; the statistic + (when (and (> span 0) + (> (/ (float len) (float span)) 0.70)) + (nconc (aref time-out i) + (list (- (timeclock-time-to-seconds + (timeclock-day-end (car day-list))) + base))) + (nconc (aref breaks i) (list (- span len)))) + (if req + (setq len (+ len (- timeclock-workday req)))) + (nconc (aref workday i) (list len))))) + (setq i (1+ i)))) + (setq day-list (cdr day-list))) + ;; average statistics + (let ((i 0) (l 5)) + (while (< i l) + (aset time-in i (timeclock-geometric-mean + (cdr (aref time-in i)))) + (aset time-out i (timeclock-geometric-mean + (cdr (aref time-out i)))) + (aset breaks i (timeclock-geometric-mean + (cdr (aref breaks i)))) + (aset workday i (timeclock-geometric-mean + (cdr (aref workday i)))) + (setq i (1+ i)))) + ;; Output the HTML table + (insert "<tr>\n") + (insert "<td align=\"center\">Time in</td>\n") + (let ((i 0) (l 5)) + (while (< i l) + (insert "<td align=\"right\">" + (timeclock-seconds-to-string (aref time-in i)) + "</td>\n") + (setq i (1+ i)))) + (insert "</tr>\n") + + (insert "<tr>\n") + (insert "<td align=\"center\">Time out</td>\n") + (let ((i 0) (l 5)) + (while (< i l) + (insert "<td align=\"right\">" + (timeclock-seconds-to-string (aref time-out i)) + "</td>\n") + (setq i (1+ i)))) + (insert "</tr>\n") + + (insert "<tr>\n") + (insert "<td align=\"center\">Break</td>\n") + (let ((i 0) (l 5)) + (while (< i l) + (insert "<td align=\"right\">" + (timeclock-seconds-to-string (aref breaks i)) + "</td>\n") + (setq i (1+ i)))) + (insert "</tr>\n") + + (insert "<tr>\n") + (insert "<td align=\"center\">Workday</td>\n") + (let ((i 0) (l 5)) + (while (< i l) + (insert "<td align=\"right\">" + (timeclock-seconds-to-string (aref workday i)) + "</td>\n") + (setq i (1+ i)))) + (insert "</tr>\n")) + (insert "<tfoot> <td colspan=\"6\" align=\"center\"> <i>These are approximate figures</i></td> </tfoot> diff --git a/src/account.cc b/src/account.cc index 37ff83f3..4170a4d2 100644 --- a/src/account.cc +++ b/src/account.cc @@ -44,14 +44,14 @@ account_t::~account_t() foreach (accounts_map::value_type& pair, accounts) { if (! pair.second->has_flags(ACCOUNT_TEMP) || - has_flags(ACCOUNT_TEMP)) { + has_flags(ACCOUNT_TEMP)) { checked_delete(pair.second); } } } account_t * account_t::find_account(const string& name, - const bool auto_create) + const bool auto_create) { accounts_map::const_iterator i = accounts.find(name); if (i != accounts.end()) @@ -111,7 +111,7 @@ namespace { foreach (accounts_map::value_type& pair, account->accounts) if (account_t * a = find_account_re_(pair.second, regexp)) - return a; + return a; return NULL; } @@ -135,13 +135,13 @@ string account_t::fullname() const if (! _fullname.empty()) { return _fullname; } else { - const account_t * first = this; - string fullname = name; + const account_t * first = this; + string fullname = name; while (first->parent) { first = first->parent; if (! first->name.empty()) - fullname = first->name + ":" + fullname; + fullname = first->name + ":" + fullname; } _fullname = fullname; @@ -161,7 +161,7 @@ string account_t::partial_name(bool flat) const std::size_t count = acct->children_with_flags(ACCOUNT_EXT_TO_DISPLAY); assert(count > 0); if (count > 1 || acct->has_xflags(ACCOUNT_EXT_TO_DISPLAY)) - break; + break; } pname = acct->name + ":" + pname; } @@ -179,7 +179,7 @@ namespace { { in_context_t<account_t> env(scope, "&b"); return string_value(env->partial_name(env.has(0) ? - env.get<bool>(0) : false)); + env.get<bool>(0) : false)); } value_t get_account(account_t& account) { // this gets the name @@ -230,12 +230,12 @@ namespace { { std::size_t depth = 0; for (const account_t * acct = account.parent; - acct && acct->parent; - acct = acct->parent) { + acct && acct->parent; + acct = acct->parent) { std::size_t count = acct->children_with_flags(ACCOUNT_EXT_TO_DISPLAY); assert(count > 0); if (count > 1 || acct->has_xflags(ACCOUNT_EXT_TO_DISPLAY)) - depth++; + depth++; } std::ostringstream out; @@ -269,7 +269,7 @@ namespace { foreach (post_t * p, account.posts) { bind_scope_t bound_scope(scope, *p); if (expr.calc(bound_scope).to_boolean()) - return true; + return true; } return false; } @@ -284,14 +284,14 @@ namespace { foreach (post_t * p, account.posts) { bind_scope_t bound_scope(scope, *p); if (! expr.calc(bound_scope).to_boolean()) - return false; + return false; } return true; } } expr_t::ptr_op_t account_t::lookup(const symbol_t::kind_t kind, - const string& name) + const string& name) { if (kind != symbol_t::FUNCTION) return NULL; @@ -407,7 +407,7 @@ bool account_t::children_with_xdata() const { foreach (const accounts_map::value_type& pair, accounts) if (pair.second->has_xdata() || - pair.second->children_with_xdata()) + pair.second->children_with_xdata()) return true; return false; @@ -420,7 +420,7 @@ std::size_t account_t::children_with_flags(xdata_t::flags_t flags) const foreach (const accounts_map::value_type& pair, accounts) if (pair.second->has_xflags(flags) || - pair.second->children_with_flags(flags)) + pair.second->children_with_flags(flags)) count++; // Although no immediately children were visited, if any progeny at all were @@ -434,11 +434,11 @@ std::size_t account_t::children_with_flags(xdata_t::flags_t flags) const account_t::xdata_t::details_t& account_t::xdata_t::details_t::operator+=(const details_t& other) { - posts_count += other.posts_count; - posts_virtuals_count += other.posts_virtuals_count; - posts_cleared_count += other.posts_cleared_count; - posts_last_7_count += other.posts_last_7_count; - posts_last_30_count += other.posts_last_30_count; + posts_count += other.posts_count; + posts_virtuals_count += other.posts_virtuals_count; + posts_cleared_count += other.posts_cleared_count; + posts_last_7_count += other.posts_last_7_count; + posts_last_30_count += other.posts_last_30_count; posts_this_month_count += other.posts_this_month_count; if (! is_valid(earliest_post) || @@ -461,9 +461,9 @@ account_t::xdata_t::details_t::operator+=(const details_t& other) filenames.insert(other.filenames.begin(), other.filenames.end()); accounts_referenced.insert(other.accounts_referenced.begin(), - other.accounts_referenced.end()); + other.accounts_referenced.end()); payees_referenced.insert(other.payees_referenced.begin(), - other.payees_referenced.end()); + other.payees_referenced.end()); return *this; } @@ -487,10 +487,10 @@ value_t account_t::amount(const optional<expr_t&>& expr) const for (; i != posts.end(); i++) { if ((*i)->xdata().has_flags(POST_EXT_VISITED)) { - if (! (*i)->xdata().has_flags(POST_EXT_CONSIDERED)) { - (*i)->add_to_value(xdata_->self_details.total, expr); - (*i)->xdata().add_flags(POST_EXT_CONSIDERED); - } + if (! (*i)->xdata().has_flags(POST_EXT_CONSIDERED)) { + (*i)->add_to_value(xdata_->self_details.total, expr); + (*i)->xdata().add_flags(POST_EXT_CONSIDERED); + } } xdata_->self_details.last_post = i; } @@ -502,10 +502,10 @@ value_t account_t::amount(const optional<expr_t&>& expr) const for (; i != xdata_->reported_posts.end(); i++) { if ((*i)->xdata().has_flags(POST_EXT_VISITED)) { - if (! (*i)->xdata().has_flags(POST_EXT_CONSIDERED)) { - (*i)->add_to_value(xdata_->self_details.total, expr); - (*i)->xdata().add_flags(POST_EXT_CONSIDERED); - } + if (! (*i)->xdata().has_flags(POST_EXT_CONSIDERED)) { + (*i)->add_to_value(xdata_->self_details.total, expr); + (*i)->xdata().add_flags(POST_EXT_CONSIDERED); + } } xdata_->self_details.last_reported_post = i; } @@ -525,7 +525,7 @@ value_t account_t::total(const optional<expr_t&>& expr) const foreach (const accounts_map::value_type& pair, accounts) { temp = pair.second->total(expr); if (! temp.is_null()) - add_or_set_value(xdata_->family_details.total, temp); + add_or_set_value(xdata_->family_details.total, temp); } temp = amount(expr); @@ -562,7 +562,7 @@ account_t::family_details(bool gather_all) const } void account_t::xdata_t::details_t::update(post_t& post, - bool gather_all) + bool gather_all) { posts_count++; @@ -592,10 +592,10 @@ void account_t::xdata_t::details_t::update(post_t& post, posts_cleared_count++; if (! is_valid(earliest_cleared_post) || - post.date() < earliest_cleared_post) + post.date() < earliest_cleared_post) earliest_cleared_post = post.date(); if (! is_valid(latest_cleared_post) || - post.date() > latest_cleared_post) + post.date() > latest_cleared_post) latest_cleared_post = post.date(); } diff --git a/src/account.h b/src/account.h index 0a3a75e4..d22d2bb3 100644 --- a/src/account.h +++ b/src/account.h @@ -55,24 +55,24 @@ typedef std::map<const string, account_t *> accounts_map; class account_t : public supports_flags<>, public scope_t { -#define ACCOUNT_NORMAL 0x00 // no flags at all, a basic account -#define ACCOUNT_KNOWN 0x01 -#define ACCOUNT_TEMP 0x02 // account is a temporary object -#define ACCOUNT_GENERATED 0x04 // account never actually existed +#define ACCOUNT_NORMAL 0x00 // no flags at all, a basic account +#define ACCOUNT_KNOWN 0x01 +#define ACCOUNT_TEMP 0x02 // account is a temporary object +#define ACCOUNT_GENERATED 0x04 // account never actually existed public: - account_t * parent; - string name; + account_t * parent; + string name; optional<string> note; unsigned short depth; - accounts_map accounts; - posts_list posts; + accounts_map accounts; + posts_list posts; mutable string _fullname; account_t(account_t * _parent = NULL, - const string& _name = "", - const optional<string>& _note = none) + const string& _name = "", + const optional<string>& _note = none) : supports_flags<>(), scope_t(), parent(_parent), name(_name), note(_note), depth(static_cast<unsigned short>(parent ? parent->depth + 1 : 0)) { @@ -107,7 +107,7 @@ public: account_t * find_account_re(const string& regexp); typedef transform_iterator<function<account_t *(accounts_map::value_type&)>, - accounts_map::iterator> + accounts_map::iterator> accounts_map_seconds_iterator; accounts_map_seconds_iterator accounts_begin() { @@ -132,7 +132,7 @@ public: } virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name); + const string& name); bool valid() const; @@ -140,50 +140,50 @@ public: struct xdata_t : public supports_flags<> { -#define ACCOUNT_EXT_SORT_CALC 0x01 +#define ACCOUNT_EXT_SORT_CALC 0x01 #define ACCOUNT_EXT_HAS_NON_VIRTUALS 0x02 #define ACCOUNT_EXT_HAS_UNB_VIRTUALS 0x04 #define ACCOUNT_EXT_AUTO_VIRTUALIZE 0x08 #define ACCOUNT_EXT_VISITED 0x10 #define ACCOUNT_EXT_MATCHING 0x20 -#define ACCOUNT_EXT_TO_DISPLAY 0x40 -#define ACCOUNT_EXT_DISPLAYED 0x80 +#define ACCOUNT_EXT_TO_DISPLAY 0x40 +#define ACCOUNT_EXT_DISPLAYED 0x80 struct details_t { - value_t total; - bool calculated; - bool gathered; - - std::size_t posts_count; - std::size_t posts_virtuals_count; - std::size_t posts_cleared_count; - std::size_t posts_last_7_count; - std::size_t posts_last_30_count; - std::size_t posts_this_month_count; - - date_t earliest_post; - date_t earliest_cleared_post; - date_t latest_post; - date_t latest_cleared_post; - - std::set<path> filenames; - std::set<string> accounts_referenced; - std::set<string> payees_referenced; + value_t total; + bool calculated; + bool gathered; + + std::size_t posts_count; + std::size_t posts_virtuals_count; + std::size_t posts_cleared_count; + std::size_t posts_last_7_count; + std::size_t posts_last_30_count; + std::size_t posts_this_month_count; + + date_t earliest_post; + date_t earliest_cleared_post; + date_t latest_post; + date_t latest_cleared_post; + + std::set<path> filenames; + std::set<string> accounts_referenced; + std::set<string> payees_referenced; optional<posts_list::const_iterator> last_post; optional<posts_list::const_iterator> last_reported_post; details_t() - : calculated(false), - gathered(false), + : calculated(false), + gathered(false), - posts_count(0), - posts_virtuals_count(0), - posts_cleared_count(0), - posts_last_7_count(0), - posts_last_30_count(0), - posts_this_month_count(0) {} + posts_count(0), + posts_virtuals_count(0), + posts_cleared_count(0), + posts_last_7_count(0), + posts_last_30_count(0), + posts_this_month_count(0) {} details_t& operator+=(const details_t& other); @@ -202,9 +202,9 @@ public: } xdata_t(const xdata_t& other) : supports_flags<>(other.flags()), - self_details(other.self_details), - family_details(other.family_details), - sort_values(other.sort_values) + self_details(other.self_details), + family_details(other.family_details), + sort_values(other.sort_values) { TRACE_CTOR(account_t::xdata_t, "copy"); } diff --git a/src/accum.cc b/src/accum.cc index 62e36deb..157f459d 100644 --- a/src/accum.cc +++ b/src/accum.cc @@ -40,8 +40,6 @@ std::streamsize straccbuf::xsputn(const char * s, std::streamsize num) if (index == 0) { // The first item received is the format string str = std::string(s, num); - index++; - return num; } else { std::ostringstream buf; @@ -51,26 +49,26 @@ std::streamsize straccbuf::xsputn(const char * s, std::streamsize num) bool matched = false; for (const char * p = str.c_str(); *p; p++) { if (*p == '%') { - const char * q = p + 1; - if (*q && *q != '%' && std::isdigit(*q) && - std::string::size_type(*q - '0') == index) { - p++; - buf << std::string(s, num); - matched = true; - } else { - buf << *p; - } + const char * q = p + 1; + if (*q && *q != '%' && std::isdigit(*q) && + std::string::size_type(*q - '0') == index) { + p++; + buf << std::string(s, num); + matched = true; + } else { + buf << *p; + } } else { - buf << *p; + buf << *p; } } if (! matched) buf << std::string(s, num); str = buf.str(); - index++; - return num; } + index++; + return num; } } // namespace ledger diff --git a/src/accum.h b/src/accum.h index 94e79948..236a7714 100644 --- a/src/accum.h +++ b/src/accum.h @@ -47,7 +47,7 @@ namespace ledger { class straccbuf : public std::streambuf { protected: - std::string str; // accumulator + std::string str; // accumulator std::string::size_type index; public: @@ -70,6 +70,8 @@ public: } void clear() { + std::ostream::clear(); + buf.pubseekoff(0, ios_base::beg); buf.str.clear(); buf.index = 0; } @@ -79,7 +81,7 @@ public: } }; -#define ACCUM(obj) (static_cast<straccstream&>(obj).str()) +#define ACCUM(obj) (static_cast<const straccstream&>(obj).str()) } // namespace ledger diff --git a/src/amount.cc b/src/amount.cc index 01caf4ac..9817f464 100644 --- a/src/amount.cc +++ b/src/amount.cc @@ -56,8 +56,8 @@ struct amount_t::bigint_t : public supports_flags<> #define BIGINT_BULK_ALLOC 0x01 #define BIGINT_KEEP_PREC 0x02 - mpq_t val; - precision_t prec; + mpq_t val; + precision_t prec; uint_least32_t refc; #define MP(bigint) ((bigint)->val) @@ -68,7 +68,7 @@ struct amount_t::bigint_t : public supports_flags<> } bigint_t(const bigint_t& other) : supports_flags<>(static_cast<uint_least8_t> - (other.flags() & ~BIGINT_BULK_ALLOC)), + (other.flags() & ~BIGINT_BULK_ALLOC)), prec(other.prec), refc(1) { TRACE_CTOR(bigint_t, "copy"); mpq_init(val); @@ -87,7 +87,7 @@ struct amount_t::bigint_t : public supports_flags<> } if (flags() & ~(BIGINT_BULK_ALLOC | BIGINT_KEEP_PREC)) { DEBUG("ledger.validate", - "amount_t::bigint_t: flags() & ~(BULK_ALLOC | KEEP_PREC)"); + "amount_t::bigint_t: flags() & ~(BULK_ALLOC | KEEP_PREC)"); return false; } return true; @@ -111,18 +111,18 @@ private: bool amount_t::is_initialized = false; namespace { - void stream_out_mpq(std::ostream& out, - mpq_t quant, - amount_t::precision_t precision, - int zeros_prec = -1, - const optional<commodity_t&>& comm = none) + void stream_out_mpq(std::ostream& out, + mpq_t quant, + amount_t::precision_t precision, + int zeros_prec = -1, + const optional<commodity_t&>& comm = none) { char * buf = NULL; try { IF_DEBUG("amount.convert") { - char * tbuf = mpq_get_str(NULL, 10, quant); - DEBUG("amount.convert", "Rational to convert = " << tbuf); - std::free(tbuf); + char * tbuf = mpq_get_str(NULL, 10, quant); + DEBUG("amount.convert", "Rational to convert = " << tbuf); + std::free(tbuf); } // Convert the rational number to a floating-point, extending the @@ -131,7 +131,7 @@ namespace { mp_prec_t num_prec = mpz_sizeinbase(mpq_numref(quant), 2); num_prec += amount_t::extend_by_digits*64; if (num_prec < MPFR_PREC_MIN) - num_prec = MPFR_PREC_MIN; + num_prec = MPFR_PREC_MIN; DEBUG("amount.convert", "num prec = " << num_prec); mpfr_set_prec(tempfnum, num_prec); @@ -140,7 +140,7 @@ namespace { mp_prec_t den_prec = mpz_sizeinbase(mpq_denref(quant), 2); den_prec += amount_t::extend_by_digits*64; if (den_prec < MPFR_PREC_MIN) - den_prec = MPFR_PREC_MIN; + den_prec = MPFR_PREC_MIN; DEBUG("amount.convert", "den prec = " << den_prec); mpfr_set_prec(tempfden, den_prec); @@ -150,73 +150,73 @@ namespace { mpfr_div(tempfb, tempfnum, tempfden, GMP_RNDN); if (mpfr_asprintf(&buf, "%.*RNf", precision, tempfb) < 0) - throw_(amount_error, - _("Cannot output amount to a floating-point representation")); - + throw_(amount_error, + _("Cannot output amount to a floating-point representation")); + DEBUG("amount.convert", "mpfr_print = " << buf - << " (precision " << precision - << ", zeros_prec " << zeros_prec << ")"); + << " (precision " << precision + << ", zeros_prec " << zeros_prec << ")"); if (zeros_prec >= 0) { - string::size_type index = std::strlen(buf); - string::size_type point = 0; - for (string::size_type i = 0; i < index; i++) { - if (buf[i] == '.') { - point = i; - break; - } - } - if (point > 0) { - while (--index >= (point + 1 + zeros_prec) && buf[index] == '0') - buf[index] = '\0'; - if (index >= (point + zeros_prec) && buf[index] == '.') - buf[index] = '\0'; - } + string::size_type index = std::strlen(buf); + string::size_type point = 0; + for (string::size_type i = 0; i < index; i++) { + if (buf[i] == '.') { + point = i; + break; + } + } + if (point > 0) { + while (--index >= (point + 1 + zeros_prec) && buf[index] == '0') + buf[index] = '\0'; + if (index >= (point + zeros_prec) && buf[index] == '.') + buf[index] = '\0'; + } } if (comm) { - int integer_digits = 0; - if (comm && comm->has_flags(COMMODITY_STYLE_THOUSANDS)) { - // Count the number of integer digits - for (const char * p = buf; *p; p++) { - if (*p == '.') - break; - else if (*p != '-') - integer_digits++; - } - } - - for (const char * p = buf; *p; p++) { - if (*p == '.') { - if (commodity_t::decimal_comma_by_default || - (comm && comm->has_flags(COMMODITY_STYLE_DECIMAL_COMMA))) - out << ','; - else - out << *p; - assert(integer_digits <= 3); - } - else if (*p == '-') { - out << *p; - } - else { - out << *p; - - if (integer_digits > 3 && --integer_digits % 3 == 0) { - if (commodity_t::decimal_comma_by_default || - (comm && comm->has_flags(COMMODITY_STYLE_DECIMAL_COMMA))) - out << '.'; - else - out << ','; - } - } - } + int integer_digits = 0; + if (comm && comm->has_flags(COMMODITY_STYLE_THOUSANDS)) { + // Count the number of integer digits + for (const char * p = buf; *p; p++) { + if (*p == '.') + break; + else if (*p != '-') + integer_digits++; + } + } + + for (const char * p = buf; *p; p++) { + if (*p == '.') { + if (commodity_t::decimal_comma_by_default || + (comm && comm->has_flags(COMMODITY_STYLE_DECIMAL_COMMA))) + out << ','; + else + out << *p; + assert(integer_digits <= 3); + } + else if (*p == '-') { + out << *p; + } + else { + out << *p; + + if (integer_digits > 3 && --integer_digits % 3 == 0) { + if (commodity_t::decimal_comma_by_default || + (comm && comm->has_flags(COMMODITY_STYLE_DECIMAL_COMMA))) + out << '.'; + else + out << ','; + } + } + } } else { - out << buf; + out << buf; } } catch (...) { if (buf != NULL) - mpfr_free_str(buf); + mpfr_free_str(buf); throw; } if (buf != NULL) @@ -288,7 +288,7 @@ void amount_t::_copy(const amount_t& amt) } else { quantity = amt.quantity; DEBUG("amounts.refs", - quantity << " refc++, now " << (quantity->refc + 1)); + quantity << " refc++, now " << (quantity->refc + 1)); quantity->refc++; } } @@ -391,8 +391,8 @@ int amount_t::compare(const amount_t& amt) const if (has_commodity() && amt.has_commodity() && commodity() != amt.commodity()) throw_(amount_error, - _("Cannot compare amounts with different commodities: %1 and %2") - << commodity().symbol() << amt.commodity().symbol()); + _("Cannot compare amounts with different commodities: %1 and %2") + << commodity().symbol() << amt.commodity().symbol()); return mpq_cmp(MP(quantity), MP(amt.quantity)); } @@ -426,9 +426,9 @@ amount_t& amount_t::operator+=(const amount_t& amt) if (has_commodity() && amt.has_commodity() && commodity() != amt.commodity()) throw_(amount_error, - _("Adding amounts with different commodities: %1 != %2") - << (has_commodity() ? commodity().symbol() : _("NONE")) - << (amt.has_commodity() ? amt.commodity().symbol() : _("NONE"))); + _("Adding amounts with different commodities: %1 != %2") + << (has_commodity() ? commodity().symbol() : _("NONE")) + << (amt.has_commodity() ? amt.commodity().symbol() : _("NONE"))); _dup(); @@ -457,9 +457,9 @@ amount_t& amount_t::operator-=(const amount_t& amt) if (has_commodity() && amt.has_commodity() && commodity() != amt.commodity()) throw_(amount_error, - _("Subtracting amounts with different commodities: %1 != %2") - << (has_commodity() ? commodity().symbol() : _("NONE")) - << (amt.has_commodity() ? amt.commodity().symbol() : _("NONE"))); + _("Subtracting amounts with different commodities: %1 != %2") + << (has_commodity() ? commodity().symbol() : _("NONE")) + << (amt.has_commodity() ? amt.commodity().symbol() : _("NONE"))); _dup(); @@ -527,7 +527,7 @@ amount_t& amount_t::operator/=(const amount_t& amt) mpq_div(MP(quantity), MP(quantity), MP(amt.quantity)); quantity->prec = static_cast<precision_t>(quantity->prec + amt.quantity->prec + - extend_by_digits); + extend_by_digits); if (! has_commodity()) commodity_ = amt.commodity_; @@ -550,7 +550,7 @@ amount_t::precision_t amount_t::precision() const { if (! quantity) throw_(amount_error, - _("Cannot determine precision of an uninitialized amount")); + _("Cannot determine precision of an uninitialized amount")); return quantity->prec; } @@ -559,7 +559,7 @@ bool amount_t::keep_precision() const { if (! quantity) throw_(amount_error, - _("Cannot determine if precision of an uninitialized amount is kept")); + _("Cannot determine if precision of an uninitialized amount is kept")); return quantity->has_flags(BIGINT_KEEP_PREC); } @@ -568,7 +568,7 @@ void amount_t::set_keep_precision(const bool keep) const { if (! quantity) throw_(amount_error, - _("Cannot set whether to keep the precision of an uninitialized amount")); + _("Cannot set whether to keep the precision of an uninitialized amount")); if (keep) quantity->add_flags(BIGINT_KEEP_PREC); @@ -580,7 +580,7 @@ amount_t::precision_t amount_t::display_precision() const { if (! quantity) throw_(amount_error, - _("Cannot determine display precision of an uninitialized amount")); + _("Cannot determine display precision of an uninitialized amount")); commodity_t& comm(commodity()); @@ -632,7 +632,7 @@ void amount_t::in_place_truncate() _dup(); DEBUG("amount.truncate", - "Truncating " << *this << " to precision " << display_precision()); + "Truncating " << *this << " to precision " << display_precision()); std::ostringstream out; stream_out_mpq(out, MP(quantity), display_precision()); @@ -704,9 +704,9 @@ void amount_t::in_place_unreduce() if (! quantity) throw_(amount_error, _("Cannot unreduce an uninitialized amount")); - amount_t temp = *this; - commodity_t * comm = commodity_; - bool shifted = false; + amount_t temp = *this; + commodity_t * comm = commodity_; + bool shifted = false; while (comm && comm->larger()) { amount_t next_temp = temp / comm->larger()->number(); @@ -725,57 +725,57 @@ void amount_t::in_place_unreduce() optional<amount_t> amount_t::value(const optional<datetime_t>& moment, - const optional<commodity_t&>& in_terms_of) const + const optional<commodity_t&>& in_terms_of) const { if (quantity) { #if defined(DEBUG_ON) DEBUG("commodity.prices.find", - "amount_t::value of " << commodity().symbol()); + "amount_t::value of " << commodity().symbol()); if (moment) DEBUG("commodity.prices.find", - "amount_t::value: moment = " << *moment); + "amount_t::value: moment = " << *moment); if (in_terms_of) DEBUG("commodity.prices.find", - "amount_t::value: in_terms_of = " << in_terms_of->symbol()); + "amount_t::value: in_terms_of = " << in_terms_of->symbol()); #endif if (has_commodity() && - (in_terms_of || ! commodity().has_flags(COMMODITY_PRIMARY))) { + (in_terms_of || ! commodity().has_flags(COMMODITY_PRIMARY))) { optional<price_point_t> point; optional<commodity_t&> comm(in_terms_of); if (comm && commodity().referent() == comm->referent()) { - return *this; + return *this; } else if (has_annotation() && annotation().price) { - if (annotation().has_flags(ANNOTATION_PRICE_FIXATED)) { - point = price_point_t(); - point->price = *annotation().price; - } - else if (! in_terms_of) { - comm = annotation().price->commodity(); - } + if (annotation().has_flags(ANNOTATION_PRICE_FIXATED)) { + point = price_point_t(); + point->price = *annotation().price; + } + else if (! in_terms_of) { + comm = annotation().price->commodity(); + } } if (! point) { - point = commodity().find_price(comm, moment); - // Whether a price was found or not, check whether we should attempt - // to download a price from the Internet. This is done if (a) no - // price was found, or (b) the price is "stale" according to the - // setting of --price-exp. - if (point) - point = commodity().check_for_updated_price(point, moment, comm); + point = commodity().find_price(comm, moment); + // Whether a price was found or not, check whether we should attempt + // to download a price from the Internet. This is done if (a) no + // price was found, or (b) the price is "stale" according to the + // setting of --price-exp. + if (point) + point = commodity().check_for_updated_price(point, moment, comm); } if (point) { - amount_t price(point->price); - price.multiply(*this, true); - price.in_place_round(); - return price; + amount_t price(point->price); + price.multiply(*this, true); + price.in_place_round(); + return price; } } } else { throw_(amount_error, - _("Cannot determine value of an uninitialized amount")); + _("Cannot determine value of an uninitialized amount")); } return none; } @@ -813,7 +813,7 @@ bool amount_t::is_zero() const return true; } else if (mpz_cmp(mpq_numref(MP(quantity)), - mpq_denref(MP(quantity))) > 0) { + mpq_denref(MP(quantity))) > 0) { DEBUG("amount.is_zero", "Numerator is larger than the denominator"); return false; } @@ -825,9 +825,9 @@ bool amount_t::is_zero() const string output = out.str(); if (! output.empty()) { - for (const char * p = output.c_str(); *p; p++) - if (*p != '0' && *p != '.' && *p != '-') - return false; + for (const char * p = output.c_str(); *p; p++) + if (*p != '0' && *p != '.' && *p != '-') + return false; } return true; } @@ -863,7 +863,7 @@ bool amount_t::fits_in_long() const commodity_t& amount_t::commodity() const { return (has_commodity() ? - *commodity_ : *commodity_pool_t::current_pool->null_commodity); + *commodity_ : *commodity_pool_t::current_pool->null_commodity); } bool amount_t::has_commodity() const @@ -873,13 +873,13 @@ bool amount_t::has_commodity() const void amount_t::annotate(const annotation_t& details) { - commodity_t * this_base; + commodity_t * this_base; annotated_commodity_t * this_ann = NULL; if (! quantity) throw_(amount_error, _("Cannot annotate the commodity of an uninitialized amount")); else if (! has_commodity()) - return; // ignore attempt to annotate a "bare commodity + return; // ignore attempt to annotate a "bare commodity if (commodity().has_annotation()) { this_ann = &as_annotated_commodity(commodity()); @@ -890,7 +890,7 @@ void amount_t::annotate(const annotation_t& details) assert(this_base); DEBUG("amounts.commodities", "Annotating commodity for amount " - << *this << std::endl << details); + << *this << std::endl << details); if (commodity_t * ann_comm = this_base->pool().find_or_create(*this_base, details)) @@ -907,10 +907,10 @@ bool amount_t::has_annotation() const { if (! quantity) throw_(amount_error, - _("Cannot determine if an uninitialized amount's commodity is annotated")); + _("Cannot determine if an uninitialized amount's commodity is annotated")); assert(! has_commodity() || ! commodity().has_annotation() || - as_annotated_commodity(commodity()).details); + as_annotated_commodity(commodity()).details); return has_commodity() && commodity().has_annotation(); } @@ -918,11 +918,11 @@ annotation_t& amount_t::annotation() { if (! quantity) throw_(amount_error, - _("Cannot return commodity annotation details of an uninitialized amount")); + _("Cannot return commodity annotation details of an uninitialized amount")); if (! commodity().has_annotation()) throw_(amount_error, - _("Request for annotation details from an unannotated amount")); + _("Request for annotation details from an unannotated amount")); annotated_commodity_t& ann_comm(as_annotated_commodity(commodity())); return ann_comm.details; @@ -932,7 +932,7 @@ amount_t amount_t::strip_annotations(const keep_details_t& what_to_keep) const { if (! quantity) throw_(amount_error, - _("Cannot strip commodity annotations from an uninitialized amount")); + _("Cannot strip commodity annotations from an uninitialized amount")); if (! what_to_keep.keep_all(commodity())) { amount_t t(*this); @@ -949,7 +949,7 @@ namespace { char buf[256]; char c = peek_next_nonws(in); READ_INTO(in, buf, 255, c, - std::isdigit(c) || c == '-' || c == '.' || c == ','); + std::isdigit(c) || c == '-' || c == '.' || c == ','); string::size_type len = std::strlen(buf); while (len > 0 && ! std::isdigit(buf[len - 1])) { @@ -971,7 +971,7 @@ bool amount_t::parse(std::istream& in, const parse_flags_t& flags) string symbol; string quant; annotation_t details; - bool negative = false; + bool negative = false; commodity_t::flags_t comm_flags = COMMODITY_STYLE_DEFAULTS; @@ -988,28 +988,28 @@ bool amount_t::parse(std::istream& in, const parse_flags_t& flags) if (! in.eof() && ((n = static_cast<char>(in.peek())) != '\n')) { if (std::isspace(n)) - comm_flags |= COMMODITY_STYLE_SEPARATED; + comm_flags |= COMMODITY_STYLE_SEPARATED; commodity_t::parse_symbol(in, symbol); if (! symbol.empty()) - comm_flags |= COMMODITY_STYLE_SUFFIXED; + comm_flags |= COMMODITY_STYLE_SUFFIXED; if (! in.eof() && ((n = static_cast<char>(in.peek())) != '\n')) - details.parse(in); + details.parse(in); } } else { commodity_t::parse_symbol(in, symbol); if (! in.eof() && ((n = static_cast<char>(in.peek())) != '\n')) { if (std::isspace(static_cast<char>(in.peek()))) - comm_flags |= COMMODITY_STYLE_SEPARATED; + comm_flags |= COMMODITY_STYLE_SEPARATED; parse_quantity(in, quant); if (! quant.empty() && ! in.eof() && - ((n = static_cast<char>(in.peek())) != '\n')) - details.parse(in); + ((n = static_cast<char>(in.peek())) != '\n')) + details.parse(in); } } @@ -1059,7 +1059,7 @@ bool amount_t::parse(std::istream& in, const parse_flags_t& flags) if (details) commodity_ = - commodity_pool_t::current_pool->find_or_create(*commodity_, details); + commodity_pool_t::current_pool->find_or_create(*commodity_, details); } // Quickly scan through and verify the correctness of the amount's use of @@ -1083,59 +1083,59 @@ bool amount_t::parse(std::istream& in, const parse_flags_t& flags) if (ch == '.') { if (no_more_periods) - throw_(amount_error, _("Too many periods in amount")); + throw_(amount_error, _("Too many periods in amount")); if (decimal_comma_style) { - if (decimal_offset % 3 != 0) - throw_(amount_error, _("Incorrect use of thousand-mark period")); - comm_flags |= COMMODITY_STYLE_THOUSANDS; - no_more_commas = true; + if (decimal_offset % 3 != 0) + throw_(amount_error, _("Incorrect use of thousand-mark period")); + comm_flags |= COMMODITY_STYLE_THOUSANDS; + no_more_commas = true; } else { - if (last_comma != string::npos) { - decimal_comma_style = true; - if (decimal_offset % 3 != 0) - throw_(amount_error, _("Incorrect use of thousand-mark period")); - } else { - no_more_periods = true; - new_quantity->prec = decimal_offset; - decimal_offset = 0; - } + if (last_comma != string::npos) { + decimal_comma_style = true; + if (decimal_offset % 3 != 0) + throw_(amount_error, _("Incorrect use of thousand-mark period")); + } else { + no_more_periods = true; + new_quantity->prec = decimal_offset; + decimal_offset = 0; + } } if (last_period == string::npos) - last_period = string_index; + last_period = string_index; } else if (ch == ',') { if (no_more_commas) - throw_(amount_error, _("Too many commas in amount")); + throw_(amount_error, _("Too many commas in amount")); if (decimal_comma_style) { - if (last_period != string::npos) { - throw_(amount_error, _("Incorrect use of decimal comma")); - } else { - no_more_commas = true; - new_quantity->prec = decimal_offset; - decimal_offset = 0; - } + if (last_period != string::npos) { + throw_(amount_error, _("Incorrect use of decimal comma")); + } else { + no_more_commas = true; + new_quantity->prec = decimal_offset; + decimal_offset = 0; + } } else { - if (decimal_offset % 3 != 0) { - if (last_comma != string::npos || - last_period != string::npos) { - throw_(amount_error, _("Incorrect use of thousand-mark comma")); - } else { - decimal_comma_style = true; - no_more_commas = true; - new_quantity->prec = decimal_offset; - decimal_offset = 0; - } - } else { - comm_flags |= COMMODITY_STYLE_THOUSANDS; - no_more_periods = true; - } + if (decimal_offset % 3 != 0) { + if (last_comma != string::npos || + last_period != string::npos) { + throw_(amount_error, _("Incorrect use of thousand-mark comma")); + } else { + decimal_comma_style = true; + no_more_commas = true; + new_quantity->prec = decimal_offset; + decimal_offset = 0; + } + } else { + comm_flags |= COMMODITY_STYLE_THOUSANDS; + no_more_periods = true; + } } if (last_comma == string::npos) - last_comma = string_index; + last_comma = string_index; } else { decimal_offset++; @@ -1163,11 +1163,11 @@ bool amount_t::parse(std::istream& in, const parse_flags_t& flags) string::size_type len = quant.length(); scoped_array<char> buf(new char[len + 1]); const char * p = quant.c_str(); - char * t = buf.get(); + char * t = buf.get(); while (*p) { if (*p == ',' || *p == '.') - p++; + p++; *t++ = *p++; } *t = '\0'; @@ -1193,7 +1193,7 @@ bool amount_t::parse(std::istream& in, const parse_flags_t& flags) quantity = new_quantity.release(); if (! flags.has_flags(PARSE_NO_REDUCE)) - in_place_reduce(); // will not throw an exception + in_place_reduce(); // will not throw an exception VERIFY(valid()); @@ -1201,7 +1201,7 @@ bool amount_t::parse(std::istream& in, const parse_flags_t& flags) } void amount_t::parse_conversion(const string& larger_str, - const string& smaller_str) + const string& smaller_str) { amount_t larger, smaller; @@ -1213,7 +1213,7 @@ void amount_t::parse_conversion(const string& larger_str, if (larger.commodity()) { larger.commodity().set_smaller(smaller); larger.commodity().add_flags(smaller.commodity().flags() | - COMMODITY_NOMARKET); + COMMODITY_NOMARKET); } if (smaller.commodity()) smaller.commodity().set_larger(larger); @@ -1239,7 +1239,7 @@ void amount_t::print(std::ostream& _out, const uint_least8_t flags) const } stream_out_mpq(out, MP(quantity), display_precision(), - comm ? commodity().precision() : 0, comm); + comm ? commodity().precision() : 0, comm); if (comm.has_flags(COMMODITY_STYLE_SUFFIXED)) { if (comm.has_flags(COMMODITY_STYLE_SEPARATED)) @@ -1325,7 +1325,7 @@ void serialize(Archive& ar, MP_RAT& mpq, const unsigned int /* version */) template <class Archive> void serialize(Archive& ar, long unsigned int& integer, - const unsigned int /* version */) + const unsigned int /* version */) { ar & make_binary_object(&integer, sizeof(long unsigned int)); } @@ -1336,23 +1336,23 @@ void serialize(Archive& ar, long unsigned int& integer, BOOST_CLASS_EXPORT(ledger::annotated_commodity_t) template void boost::serialization::serialize(boost::archive::binary_iarchive&, - MP_INT&, const unsigned int); + MP_INT&, const unsigned int); template void boost::serialization::serialize(boost::archive::binary_oarchive&, - MP_INT&, const unsigned int); + MP_INT&, const unsigned int); template void boost::serialization::serialize(boost::archive::binary_iarchive&, - MP_RAT&, const unsigned int); + MP_RAT&, const unsigned int); template void boost::serialization::serialize(boost::archive::binary_oarchive&, - MP_RAT&, const unsigned int); + MP_RAT&, const unsigned int); template void boost::serialization::serialize(boost::archive::binary_iarchive&, - long unsigned int&, - const unsigned int); + long unsigned int&, + const unsigned int); template void boost::serialization::serialize(boost::archive::binary_oarchive&, - long unsigned int&, - const unsigned int); + long unsigned int&, + const unsigned int); template void ledger::amount_t::serialize(boost::archive::binary_iarchive&, - const unsigned int); + const unsigned int); template void ledger::amount_t::serialize(boost::archive::binary_oarchive&, - const unsigned int); + const unsigned int); #endif // HAVE_BOOST_SERIALIZATION diff --git a/src/amount.h b/src/amount.h index be4c5e45..929251d8 100644 --- a/src/amount.h +++ b/src/amount.h @@ -91,9 +91,9 @@ typedef basic_flags_t<parse_flags_enum_t, uint_least8_t> parse_flags_t; */ class amount_t : public ordered_field_operators<amount_t, - ordered_field_operators<amount_t, double, - ordered_field_operators<amount_t, unsigned long, - ordered_field_operators<amount_t, long> > > > + ordered_field_operators<amount_t, double, + ordered_field_operators<amount_t, unsigned long, + ordered_field_operators<amount_t, long> > > > { public: /** Ready the amount subsystem for use. @@ -125,8 +125,8 @@ protected: struct bigint_t; - bigint_t * quantity; - commodity_t * commodity_; + bigint_t * quantity; + commodity_t * commodity_; public: /** @name Constructors @@ -399,8 +399,8 @@ public: $100.00. */ optional<amount_t> - value(const optional<datetime_t>& moment = none, - const optional<commodity_t&>& in_terms_of = none) const; + value(const optional<datetime_t>& moment = none, + const optional<commodity_t&>& in_terms_of = none) const; amount_t price() const; @@ -646,16 +646,16 @@ public: parse(string, flags_t) also parses an amount from a string. */ bool parse(std::istream& in, - const parse_flags_t& flags = PARSE_DEFAULT); + const parse_flags_t& flags = PARSE_DEFAULT); bool parse(const string& str, - const parse_flags_t& flags = PARSE_DEFAULT) { + const parse_flags_t& flags = PARSE_DEFAULT) { std::istringstream stream(str); bool result = parse(stream, flags); return result; } static void parse_conversion(const string& larger_str, - const string& smaller_str); + const string& smaller_str); /*@}*/ @@ -683,7 +683,7 @@ public: #define AMOUNT_PRINT_ELIDE_COMMODITY_QUOTES 0x08 void print(std::ostream& out, - const uint_least8_t flags = AMOUNT_PRINT_NO_FLAGS) const; + const uint_least8_t flags = AMOUNT_PRINT_NO_FLAGS) const; /*@}*/ @@ -760,7 +760,7 @@ inline std::istream& operator>>(std::istream& in, amount_t& amt) { } void to_xml(std::ostream& out, const amount_t& amt, - bool commodity_details = false); + bool commodity_details = false); } // namespace ledger diff --git a/src/annotate.cc b/src/annotate.cc index e1e64ac2..08b73443 100644 --- a/src/annotate.cc +++ b/src/annotate.cc @@ -47,20 +47,20 @@ void annotation_t::parse(std::istream& in) char c = peek_next_nonws(in); if (c == '{') { if (price) - throw_(amount_error, _("Commodity specifies more than one price")); + throw_(amount_error, _("Commodity specifies more than one price")); in.get(c); c = peek_next_nonws(in); if (c == '=') { - in.get(c); - add_flags(ANNOTATION_PRICE_FIXATED); + in.get(c); + add_flags(ANNOTATION_PRICE_FIXATED); } READ_INTO(in, buf, 255, c, c != '}'); if (c == '}') - in.get(c); + in.get(c); else - throw_(amount_error, _("Commodity price lacks closing brace")); + throw_(amount_error, _("Commodity price lacks closing brace")); amount_t temp; temp.parse(buf, PARSE_NO_MIGRATE); @@ -70,27 +70,27 @@ void annotation_t::parse(std::istream& in) } else if (c == '[') { if (date) - throw_(amount_error, _("Commodity specifies more than one date")); + throw_(amount_error, _("Commodity specifies more than one date")); in.get(c); READ_INTO(in, buf, 255, c, c != ']'); if (c == ']') - in.get(c); + in.get(c); else - throw_(amount_error, _("Commodity date lacks closing bracket")); + throw_(amount_error, _("Commodity date lacks closing bracket")); date = parse_date(buf); } else if (c == '(') { if (tag) - throw_(amount_error, _("Commodity specifies more than one tag")); + throw_(amount_error, _("Commodity specifies more than one tag")); in.get(c); READ_INTO(in, buf, 255, c, c != ')'); if (c == ')') - in.get(c); + in.get(c); else - throw_(amount_error, _("Commodity tag lacks closing parenthesis")); + throw_(amount_error, _("Commodity tag lacks closing parenthesis")); tag = buf; } @@ -104,20 +104,20 @@ void annotation_t::parse(std::istream& in) #if defined(DEBUG_ON) if (SHOW_DEBUG("amounts.commodities") && *this) { DEBUG("amounts.commodities", - "Parsed commodity annotations: " << std::endl << *this); + "Parsed commodity annotations: " << std::endl << *this); } #endif } void annotation_t::print(std::ostream& out, bool keep_base, - bool no_computed_annotations) const + bool no_computed_annotations) const { if (price && (! no_computed_annotations || ! has_flags(ANNOTATION_PRICE_CALCULATED))) out << " {" - << (has_flags(ANNOTATION_PRICE_FIXATED) ? "=" : "") - << (keep_base ? *price : price->unreduced()) - << '}'; + << (has_flags(ANNOTATION_PRICE_FIXATED) ? "=" : "") + << (keep_base ? *price : price->unreduced()) + << '}'; if (date && (! no_computed_annotations || ! has_flags(ANNOTATION_DATE_CALCULATED))) @@ -131,7 +131,7 @@ void annotation_t::print(std::ostream& out, bool keep_base, bool keep_details_t::keep_all(const commodity_t& comm) const { return (! comm.has_annotation() || - (keep_price && keep_date && keep_tag && ! only_actuals)); + (keep_price && keep_date && keep_tag && ! only_actuals)); } bool keep_details_t::keep_any(const commodity_t& comm) const @@ -159,22 +159,22 @@ commodity_t& annotated_commodity_t::strip_annotations(const keep_details_t& what_to_keep) { DEBUG("commodity.annotated.strip", - "Reducing commodity " << *this << std::endl - << " keep price " << what_to_keep.keep_price << " " - << " keep date " << what_to_keep.keep_date << " " - << " keep tag " << what_to_keep.keep_tag); + "Reducing commodity " << *this << std::endl + << " keep price " << what_to_keep.keep_price << " " + << " keep date " << what_to_keep.keep_date << " " + << " keep tag " << what_to_keep.keep_tag); commodity_t * new_comm; - bool keep_price = (what_to_keep.keep_price && - (! what_to_keep.only_actuals || - ! details.has_flags(ANNOTATION_PRICE_CALCULATED))); - bool keep_date = (what_to_keep.keep_date && - (! what_to_keep.only_actuals || - ! details.has_flags(ANNOTATION_DATE_CALCULATED))); - bool keep_tag = (what_to_keep.keep_tag && - (! what_to_keep.only_actuals || - ! details.has_flags(ANNOTATION_TAG_CALCULATED))); + bool keep_price = (what_to_keep.keep_price && + (! what_to_keep.only_actuals || + ! details.has_flags(ANNOTATION_PRICE_CALCULATED))); + bool keep_date = (what_to_keep.keep_date && + (! what_to_keep.only_actuals || + ! details.has_flags(ANNOTATION_DATE_CALCULATED))); + bool keep_tag = (what_to_keep.keep_tag && + (! what_to_keep.only_actuals || + ! details.has_flags(ANNOTATION_TAG_CALCULATED))); if ((keep_price && details.price) || (keep_date && details.date) || @@ -182,8 +182,8 @@ annotated_commodity_t::strip_annotations(const keep_details_t& what_to_keep) { new_comm = pool().find_or_create (referent(), annotation_t(keep_price ? details.price : none, - keep_date ? details.date : none, - keep_tag ? details.tag : none)); + keep_date ? details.date : none, + keep_tag ? details.tag : none)); } else { new_comm = &referent(); } diff --git a/src/annotate.h b/src/annotate.h index 4f2f1b04..b590ca45 100644 --- a/src/annotate.h +++ b/src/annotate.h @@ -49,7 +49,7 @@ namespace ledger { struct annotation_t : public supports_flags<>, - public equality_comparable<annotation_t> + public equality_comparable<annotation_t> { #define ANNOTATION_PRICE_CALCULATED 0x01 #define ANNOTATION_PRICE_FIXATED 0x02 @@ -61,8 +61,8 @@ struct annotation_t : public supports_flags<>, optional<string> tag; explicit annotation_t(const optional<amount_t>& _price = none, - const optional<date_t>& _date = none, - const optional<string>& _tag = none) + const optional<date_t>& _date = none, + const optional<string>& _tag = none) : supports_flags<>(), price(_price), date(_date), tag(_tag) { TRACE_CTOR(annotation_t, "const optional<amount_t>& + date_t + string"); } @@ -81,14 +81,14 @@ struct annotation_t : public supports_flags<>, bool operator==(const annotation_t& rhs) const { return (price == rhs.price && - date == rhs.date && - tag == rhs.tag); + date == rhs.date && + tag == rhs.tag); } void parse(std::istream& in); void print(std::ostream& out, bool keep_base = false, - bool no_computed_annotations = false) const; + bool no_computed_annotations = false) const; bool valid() const { assert(*this); @@ -142,9 +142,9 @@ struct keep_details_t bool only_actuals; explicit keep_details_t(bool _keep_price = false, - bool _keep_date = false, - bool _keep_tag = false, - bool _only_actuals = false) + bool _keep_date = false, + bool _keep_tag = false, + bool _only_actuals = false) : keep_price(_keep_price), keep_date(_keep_date), keep_tag(_keep_tag), @@ -188,7 +188,7 @@ private: }; inline std::ostream& operator<<(std::ostream& out, - const annotation_t& details) { + const annotation_t& details) { details.print(out); return out; } @@ -196,8 +196,8 @@ inline std::ostream& operator<<(std::ostream& out, class annotated_commodity_t : public commodity_t, public equality_comparable<annotated_commodity_t, - equality_comparable2<annotated_commodity_t, commodity_t, - noncopyable> > + equality_comparable2<annotated_commodity_t, commodity_t, + noncopyable> > { protected: friend class commodity_pool_t; @@ -205,7 +205,7 @@ protected: commodity_t * ptr; explicit annotated_commodity_t(commodity_t * _ptr, - const annotation_t& _details) + const annotation_t& _details) : commodity_t(_ptr->parent_, _ptr->base), ptr(_ptr), details(_details) { TRACE_CTOR(annotated_commodity_t, "commodity_t *, annotation_t"); annotated = true; @@ -232,7 +232,7 @@ public: virtual commodity_t& strip_annotations(const keep_details_t& what_to_keep); virtual void write_annotations(std::ostream& out, - bool no_computed_annotations = false) const; + bool no_computed_annotations = false) const; #if defined(HAVE_BOOST_SERIALIZATION) private: diff --git a/src/archive.cc b/src/archive.cc index e7fc072e..28760512 100644 --- a/src/archive.cc +++ b/src/archive.cc @@ -59,9 +59,9 @@ BOOST_CLASS_EXPORT(ledger::auto_xact_t) BOOST_CLASS_EXPORT(ledger::period_xact_t) template void ledger::journal_t::serialize(boost::archive::binary_oarchive&, - const unsigned int); + const unsigned int); template void ledger::journal_t::serialize(boost::archive::binary_iarchive&, - const unsigned int); + const unsigned int); namespace ledger { namespace { @@ -113,7 +113,7 @@ bool archive_t::read_header() iarchive >> *this; DEBUG("archive.journal", - "Version number: " << std::hex << ARCHIVE_VERSION << std::dec); + "Version number: " << std::hex << ARCHIVE_VERSION << std::dec); DEBUG("archive.journal", "Number of sources: " << sources.size()); #if defined(DEBUG_ON) @@ -152,7 +152,7 @@ bool archive_t::should_load(const std::list<path>& data_files) if (data_files.size() != sources.size()) { DEBUG("archive.journal", "No, number of sources doesn't match: " - << data_files.size() << " != " << sources.size()); + << data_files.size() << " != " << sources.size()); return false; } @@ -171,23 +171,23 @@ bool archive_t::should_load(const std::list<path>& data_files) DEBUG("archive.journal", "Comparing against source file: " << *i.filename); if (*i.filename == p) { - if (! exists(*i.filename)) { - DEBUG("archive.journal", - "No, a referent source no longer exists: " << *i.filename); - return false; - } - - if (i.modtime != posix_time::from_time_t(last_write_time(p))) { - DEBUG("archive.journal", "No, a source's modtime has changed: " << p); - return false; - } - - if (i.size != file_size(p)) { - DEBUG("archive.journal", "No, a source's size has changed: " << p); - return false; - } - - found++; + if (! exists(*i.filename)) { + DEBUG("archive.journal", + "No, a referent source no longer exists: " << *i.filename); + return false; + } + + if (i.modtime != posix_time::from_time_t(last_write_time(p))) { + DEBUG("archive.journal", "No, a source's modtime has changed: " << p); + return false; + } + + if (i.size != file_size(p)) { + DEBUG("archive.journal", "No, a source's size has changed: " << p); + return false; + } + + found++; } } } @@ -225,7 +225,7 @@ bool archive_t::should_save(journal_t& journal) if (! exists(*i.filename)) { DEBUG("archive.journal", - "No, a source no longer exists: " << *i.filename); + "No, a source no longer exists: " << *i.filename); return false; } @@ -258,11 +258,11 @@ void archive_t::save(journal_t& journal) boost::archive::binary_oarchive oa(stream); DEBUG("archive.journal", "Creating archive with version " - << std::hex << ARCHIVE_VERSION << std::dec); + << std::hex << ARCHIVE_VERSION << std::dec); oa << *this; DEBUG("archive.journal", - "Archiving journal with " << sources.size() << " sources"); + "Archiving journal with " << sources.size() << " sources"); oa << journal; INFO_FINISH(archive); diff --git a/src/archive.h b/src/archive.h index e954cd3e..1ebf3496 100644 --- a/src/archive.h +++ b/src/archive.h @@ -48,7 +48,7 @@ namespace ledger { class archive_t { - path file; + path file; std::list<journal_t::fileinfo_t> sources; diff --git a/src/balance.cc b/src/balance.cc index a8bc649d..7ce9d994 100644 --- a/src/balance.cc +++ b/src/balance.cc @@ -35,7 +35,7 @@ #include "commodity.h" #include "annotate.h" #include "pool.h" -#include "unistring.h" // for justify() +#include "unistring.h" // for justify() namespace ledger { @@ -71,7 +71,7 @@ balance_t& balance_t::operator+=(const amount_t& amt) { if (amt.is_null()) throw_(balance_error, - _("Cannot add an uninitialized amount to a balance")); + _("Cannot add an uninitialized amount to a balance")); if (amt.is_realzero()) return *this; @@ -96,7 +96,7 @@ balance_t& balance_t::operator-=(const amount_t& amt) { if (amt.is_null()) throw_(balance_error, - _("Cannot subtract an uninitialized amount from a balance")); + _("Cannot subtract an uninitialized amount from a balance")); if (amt.is_realzero()) return *this; @@ -116,7 +116,7 @@ balance_t& balance_t::operator*=(const amount_t& amt) { if (amt.is_null()) throw_(balance_error, - _("Cannot multiply a balance by an uninitialized amount")); + _("Cannot multiply a balance by an uninitialized amount")); if (is_realzero()) { ; @@ -138,12 +138,12 @@ balance_t& balance_t::operator*=(const amount_t& amt) amounts.begin()->second *= amt; else throw_(balance_error, - _("Cannot multiply a balance with annotated commodities by a commoditized amount")); + _("Cannot multiply a balance with annotated commodities by a commoditized amount")); } else { assert(amounts.size() > 1); throw_(balance_error, - _("Cannot multiply a multi-commodity balance by a commoditized amount")); + _("Cannot multiply a multi-commodity balance by a commoditized amount")); } return *this; } @@ -152,7 +152,7 @@ balance_t& balance_t::operator/=(const amount_t& amt) { if (amt.is_null()) throw_(balance_error, - _("Cannot divide a balance by an uninitialized amount")); + _("Cannot divide a balance by an uninitialized amount")); if (is_realzero()) { ; @@ -174,19 +174,19 @@ balance_t& balance_t::operator/=(const amount_t& amt) amounts.begin()->second /= amt; else throw_(balance_error, - _("Cannot divide a balance with annotated commodities by a commoditized amount")); + _("Cannot divide a balance with annotated commodities by a commoditized amount")); } else { assert(amounts.size() > 1); throw_(balance_error, - _("Cannot divide a multi-commodity balance by a commoditized amount")); + _("Cannot divide a multi-commodity balance by a commoditized amount")); } return *this; } optional<balance_t> balance_t::value(const optional<datetime_t>& moment, - const optional<commodity_t&>& in_terms_of) const + const optional<commodity_t&>& in_terms_of) const { balance_t temp; bool resolved = false; @@ -223,11 +223,11 @@ balance_t::commodity_amount(const optional<const commodity_t&>& commodity) const // Try stripping annotations before giving an error. balance_t temp(strip_annotations(keep_details_t())); if (temp.amounts.size() == 1) - return temp.commodity_amount(commodity); + return temp.commodity_amount(commodity); throw_(amount_error, - _("Requested amount of a balance with multiple commodities: %1") - << temp); + _("Requested amount of a balance with multiple commodities: %1") + << temp); } } else if (amounts.size() > 0) { @@ -251,9 +251,9 @@ balance_t::strip_annotations(const keep_details_t& what_to_keep) const } void balance_t::print(std::ostream& out, - const int first_width, - const int latter_width, - const uint_least8_t flags) const + const int first_width, + const int latter_width, + const uint_least8_t flags) const { bool first = true; int lwidth = latter_width; @@ -269,7 +269,7 @@ void balance_t::print(std::ostream& out, sorted.push_back(&pair.second); std::stable_sort(sorted.begin(), sorted.end(), - commodity_t::compare_by_commodity()); + commodity_t::compare_by_commodity()); foreach (const amount_t * amount, sorted) { int width; @@ -284,7 +284,7 @@ void balance_t::print(std::ostream& out, std::ostringstream buf; amount->print(buf, flags); justify(out, buf.str(), width, flags & AMOUNT_PRINT_RIGHT_JUSTIFY, - flags & AMOUNT_PRINT_COLORIZE && amount->sign() < 0); + flags & AMOUNT_PRINT_COLORIZE && amount->sign() < 0); } if (first) { diff --git a/src/balance.h b/src/balance.h index 12d7bc02..ac22f3e7 100644 --- a/src/balance.h +++ b/src/balance.h @@ -65,19 +65,19 @@ DECLARE_EXCEPTION(balance_error, std::runtime_error); */ class balance_t : public equality_comparable<balance_t, - equality_comparable<balance_t, amount_t, - equality_comparable<balance_t, double, - equality_comparable<balance_t, unsigned long, - equality_comparable<balance_t, long, - additive<balance_t, - additive<balance_t, amount_t, - additive<balance_t, double, - additive<balance_t, unsigned long, - additive<balance_t, long, - multiplicative<balance_t, amount_t, - multiplicative<balance_t, double, - multiplicative<balance_t, unsigned long, - multiplicative<balance_t, long> > > > > > > > > > > > > > + equality_comparable<balance_t, amount_t, + equality_comparable<balance_t, double, + equality_comparable<balance_t, unsigned long, + equality_comparable<balance_t, long, + additive<balance_t, + additive<balance_t, amount_t, + additive<balance_t, double, + additive<balance_t, unsigned long, + additive<balance_t, long, + multiplicative<balance_t, amount_t, + multiplicative<balance_t, double, + multiplicative<balance_t, unsigned long, + multiplicative<balance_t, long> > > > > > > > > > > > > > { public: typedef std::map<commodity_t *, amount_t> amounts_map; @@ -111,7 +111,7 @@ public: TRACE_CTOR(balance_t, "const amount_t&"); if (amt.is_null()) throw_(balance_error, - _("Cannot initialize a balance from an uninitialized amount")); + _("Cannot initialize a balance from an uninitialized amount")); if (! amt.is_realzero()) amounts.insert(amounts_map::value_type(&amt.commodity(), amt)); } @@ -153,7 +153,7 @@ public: balance_t& operator=(const amount_t& amt) { if (amt.is_null()) throw_(balance_error, - _("Cannot assign an uninitialized amount to a balance")); + _("Cannot assign an uninitialized amount to a balance")); amounts.clear(); if (! amt.is_realzero()) @@ -187,17 +187,17 @@ public: bool operator==(const balance_t& bal) const { amounts_map::const_iterator i, j; for (i = amounts.begin(), j = bal.amounts.begin(); - i != amounts.end() && j != bal.amounts.end(); - i++, j++) { + i != amounts.end() && j != bal.amounts.end(); + i++, j++) { if (! (i->first == j->first && i->second == j->second)) - return false; + return false; } return i == amounts.end() && j == bal.amounts.end(); } bool operator==(const amount_t& amt) const { if (amt.is_null()) throw_(balance_error, - _("Cannot compare a balance to an uninitialized amount")); + _("Cannot compare a balance to an uninitialized amount")); if (amt.is_realzero()) return amounts.empty(); @@ -384,8 +384,8 @@ public: } optional<balance_t> - value(const optional<datetime_t>& moment = none, - const optional<commodity_t&>& in_terms_of = none) const; + value(const optional<datetime_t>& moment = none, + const optional<commodity_t&>& in_terms_of = none) const; balance_t price() const; @@ -417,7 +417,7 @@ public: foreach (const amounts_map::value_type& pair, amounts) if (pair.second.is_nonzero()) - return true; + return true; return false; } @@ -427,7 +427,7 @@ public: foreach (const amounts_map::value_type& pair, amounts) if (! pair.second.is_zero()) - return false; + return false; return true; } @@ -437,7 +437,7 @@ public: foreach (const amounts_map::value_type& pair, amounts) if (! pair.second.is_realzero()) - return false; + return false; return true; } @@ -468,7 +468,7 @@ public: return amounts.begin()->second; else throw_(balance_error, - _("Cannot convert a balance with multiple commodities to an amount")); + _("Cannot convert a balance with multiple commodities to an amount")); return amount_t(); } @@ -529,10 +529,10 @@ public: * relative amounts of those commodities. There is no option to * change this behavior. */ - void print(std::ostream& out, - const int first_width = -1, - const int latter_width = -1, - const uint_least8_t flags = AMOUNT_PRINT_NO_FLAGS) const; + void print(std::ostream& out, + const int first_width = -1, + const int latter_width = -1, + const uint_least8_t flags = AMOUNT_PRINT_NO_FLAGS) const; /** * Debugging methods. There are two methods defined to help with @@ -550,9 +550,9 @@ public: bool first = true; foreach (const amounts_map::value_type& pair, amounts) { if (first) - first = false; + first = false; else - out << ", "; + out << ", "; pair.second.print(out); } out << ")"; @@ -561,8 +561,8 @@ public: bool valid() const { foreach (const amounts_map::value_type& pair, amounts) if (! pair.second.valid()) { - DEBUG("ledger.validate", "balance_t: ! pair.second.valid()"); - return false; + DEBUG("ledger.validate", "balance_t: ! pair.second.valid()"); + return false; } return true; } diff --git a/src/chain.cc b/src/chain.cc index 9a74cdca..49e0e470 100644 --- a/src/chain.cc +++ b/src/chain.cc @@ -40,7 +40,7 @@ namespace ledger { post_handler_ptr chain_pre_post_handlers(post_handler_ptr base_handler, - report_t& report) + report_t& report) { post_handler_ptr handler(base_handler); @@ -52,11 +52,11 @@ post_handler_ptr chain_pre_post_handlers(post_handler_ptr base_handler, // This filter_posts will only pass through posts matching the `predicate'. if (report.HANDLED(limit_)) { DEBUG("report.predicate", - "Report predicate expression = " << report.HANDLER(limit_).str()); + "Report predicate expression = " << report.HANDLER(limit_).str()); handler.reset(new filter_posts - (handler, predicate_t(report.HANDLER(limit_).str(), - report.what_to_keep()), - report)); + (handler, predicate_t(report.HANDLER(limit_).str(), + report.what_to_keep()), + report)); } // budget_posts takes a set of posts from a data file and uses them to @@ -68,7 +68,7 @@ post_handler_ptr chain_pre_post_handlers(post_handler_ptr base_handler, if (report.budget_flags != BUDGET_NO_BUDGET) { budget_posts * budget_handler = new budget_posts(handler, - report.budget_flags); + report.budget_flags); budget_handler->add_period_xacts(report.session.journal->period_xacts); handler.reset(budget_handler); @@ -78,41 +78,41 @@ post_handler_ptr chain_pre_post_handlers(post_handler_ptr base_handler, // the filter get reported. if (report.HANDLED(limit_)) handler.reset(new filter_posts - (handler, predicate_t(report.HANDLER(limit_).str(), - report.what_to_keep()), - report)); + (handler, predicate_t(report.HANDLER(limit_).str(), + report.what_to_keep()), + report)); } else if (report.HANDLED(forecast_while_)) { forecast_posts * forecast_handler = new forecast_posts(handler, - predicate_t(report.HANDLER(forecast_while_).str(), - report.what_to_keep()), - report, - report.HANDLED(forecast_years_) ? - static_cast<std::size_t> - (report.HANDLER(forecast_years_).value.to_long()) : - 5UL); + predicate_t(report.HANDLER(forecast_while_).str(), + report.what_to_keep()), + report, + report.HANDLED(forecast_years_) ? + static_cast<std::size_t> + (report.HANDLER(forecast_years_).value.to_long()) : + 5UL); forecast_handler->add_period_xacts(report.session.journal->period_xacts); handler.reset(forecast_handler); // See above, under budget_posts. if (report.HANDLED(limit_)) handler.reset(new filter_posts - (handler, predicate_t(report.HANDLER(limit_).str(), - report.what_to_keep()), - report)); + (handler, predicate_t(report.HANDLER(limit_).str(), + report.what_to_keep()), + report)); } return handler; } post_handler_ptr chain_post_handlers(post_handler_ptr base_handler, - report_t& report, - bool for_accounts_report) + report_t& report, + bool for_accounts_report) { - post_handler_ptr handler(base_handler); - predicate_t display_predicate; - predicate_t only_predicate; + post_handler_ptr handler(base_handler); + predicate_t display_predicate; + predicate_t only_predicate; display_filter_posts * display_filter = NULL; assert(report.HANDLED(amount_)); @@ -123,34 +123,34 @@ post_handler_ptr chain_post_handlers(post_handler_ptr base_handler, // Make sure only forecast postings which match are allowed through if (report.HANDLED(forecast_while_)) { handler.reset(new filter_posts - (handler, predicate_t(report.HANDLER(forecast_while_).str(), - report.what_to_keep()), - report)); + (handler, predicate_t(report.HANDLER(forecast_while_).str(), + report.what_to_keep()), + report)); } // truncate_xacts cuts off a certain number of _xacts_ from being // displayed. It does not affect calculation. if (report.HANDLED(head_) || report.HANDLED(tail_)) handler.reset - (new truncate_xacts(handler, - report.HANDLED(head_) ? - report.HANDLER(head_).value.to_int() : 0, - report.HANDLED(tail_) ? - report.HANDLER(tail_).value.to_int() : 0)); + (new truncate_xacts(handler, + report.HANDLED(head_) ? + report.HANDLER(head_).value.to_int() : 0, + report.HANDLED(tail_) ? + report.HANDLER(tail_).value.to_int() : 0)); // changed_value_posts adds virtual posts to the list to account for changes // in market value of commodities, which otherwise would affect the running // total unpredictably. display_filter = new display_filter_posts(handler, report, - report.HANDLED(revalued) && - ! report.HANDLED(no_rounding)); + report.HANDLED(revalued) && + ! report.HANDLED(no_rounding)); handler.reset(display_filter); // filter_posts will only pass through posts matching the // `display_predicate'. if (report.HANDLED(display_)) { display_predicate = predicate_t(report.HANDLER(display_).str(), - report.what_to_keep()); + report.what_to_keep()); handler.reset(new filter_posts(handler, display_predicate, report)); } } @@ -161,21 +161,21 @@ post_handler_ptr chain_post_handlers(post_handler_ptr base_handler, if (report.HANDLED(revalued) && (! for_accounts_report || report.HANDLED(unrealized))) handler.reset(new changed_value_posts(handler, report, for_accounts_report, - report.HANDLED(unrealized), - display_filter)); + report.HANDLED(unrealized), + display_filter)); // calc_posts computes the running total. When this appears will determine, // for example, whether filtered posts are included or excluded from the // running total. handler.reset(new calc_posts(handler, expr, (! for_accounts_report || - (report.HANDLED(revalued) && - report.HANDLED(unrealized))))); + (report.HANDLED(revalued) && + report.HANDLED(unrealized))))); // filter_posts will only pass through posts matching the // `secondary_predicate'. if (report.HANDLED(only_)) { only_predicate = predicate_t(report.HANDLER(only_).str(), - report.what_to_keep()); + report.what_to_keep()); handler.reset(new filter_posts(handler, only_predicate, report)); } @@ -184,13 +184,13 @@ post_handler_ptr chain_post_handlers(post_handler_ptr base_handler, // value expression. if (report.HANDLED(sort_)) { if (report.HANDLED(sort_xacts_)) - handler.reset(new sort_xacts(handler, report.HANDLER(sort_).str())); + handler.reset(new sort_xacts(handler, report.HANDLER(sort_).str())); else - handler.reset(new sort_posts(handler, report.HANDLER(sort_).str())); + handler.reset(new sort_posts(handler, report.HANDLER(sort_).str())); } #if 0 else if (! report.HANDLED(period_) && - ! report.HANDLED(unsorted)) { + ! report.HANDLED(unsorted)) { handler.reset(new sort_posts(handler, "date")); } #endif @@ -199,8 +199,8 @@ post_handler_ptr chain_post_handlers(post_handler_ptr base_handler, // with a subtotaled post for each commodity used. if (report.HANDLED(collapse)) handler.reset(new collapse_posts(handler, report, expr, - display_predicate, only_predicate, - report.HANDLED(collapse_if_zero))); + display_predicate, only_predicate, + report.HANDLED(collapse_if_zero))); // subtotal_posts combines all the posts it receives into one subtotal // xact, which has one post for each commodity in each account. @@ -225,37 +225,37 @@ post_handler_ptr chain_post_handlers(post_handler_ptr base_handler, // weekly or monthly. if (report.HANDLED(period_)) { handler.reset(new interval_posts(handler, expr, - report.HANDLER(period_).str(), - report.HANDLED(exact), - report.HANDLED(empty))); + report.HANDLER(period_).str(), + report.HANDLED(exact), + report.HANDLED(empty))); handler.reset(new sort_posts(handler, "date")); } if (report.HANDLED(date_)) handler.reset(new transfer_details(handler, transfer_details::SET_DATE, - report.session.journal->master, - report.HANDLER(date_).str(), - report)); + report.session.journal->master, + report.HANDLER(date_).str(), + report)); if (report.HANDLED(account_)) { handler.reset(new transfer_details(handler, transfer_details::SET_ACCOUNT, - report.session.journal->master, - report.HANDLER(account_).str(), - report)); + report.session.journal->master, + report.HANDLER(account_).str(), + report)); } else if (report.HANDLED(pivot_)) { string pivot = report.HANDLER(pivot_).str(); pivot = string("\"") + pivot + ":\" + tag(\"" + pivot + "\")"; handler.reset(new transfer_details(handler, transfer_details::SET_ACCOUNT, - report.session.journal->master, pivot, - report)); + report.session.journal->master, pivot, + report)); } if (report.HANDLED(payee_)) handler.reset(new transfer_details(handler, transfer_details::SET_PAYEE, - report.session.journal->master, - report.HANDLER(payee_).str(), - report)); + report.session.journal->master, + report.HANDLER(payee_).str(), + report)); // related_posts will pass along all posts related to the post received. If // the `related_all' handler is on, then all the xact's posts are passed; diff --git a/src/chain.h b/src/chain.h index 1a50a077..7bd76712 100644 --- a/src/chain.h +++ b/src/chain.h @@ -94,17 +94,17 @@ class report_t; post_handler_ptr chain_pre_post_handlers(post_handler_ptr base_handler, - report_t& report); + report_t& report); post_handler_ptr chain_post_handlers(post_handler_ptr base_handler, - report_t& report, - bool for_accounts_report = false); + report_t& report, + bool for_accounts_report = false); inline post_handler_ptr chain_handlers(post_handler_ptr handler, - report_t& report, - bool for_accounts_report = false) { + report_t& report, + bool for_accounts_report = false) { handler = chain_post_handlers(handler, report, for_accounts_report); handler = chain_pre_post_handlers(handler, report); return handler; diff --git a/src/commodity.cc b/src/commodity.cc index 44d14c56..230113e8 100644 --- a/src/commodity.cc +++ b/src/commodity.cc @@ -41,13 +41,13 @@ namespace ledger { bool commodity_t::decimal_comma_by_default = false; void commodity_t::history_t::add_price(commodity_t& source, - const datetime_t& date, - const amount_t& price, - const bool reflexive) + const datetime_t& date, + const amount_t& price, + const bool reflexive) { DEBUG("commodity.prices.add", "add_price to " << source - << (reflexive ? " (secondary)" : " (primary)") - << " : " << date << ", " << price); + << (reflexive ? " (secondary)" : " (primary)") + << " : " << date << ", " << price); history_map::iterator i = prices.find(date); if (i != prices.end()) { @@ -64,7 +64,7 @@ void commodity_t::history_t::add_price(commodity_t& source, price.commodity().add_price(date, inverse, false); } else { DEBUG("commodity.prices.add", - "marking commodity " << source.symbol() << " as primary"); + "marking commodity " << source.symbol() << " as primary"); source.add_flags(COMMODITY_PRIMARY); } } @@ -81,15 +81,15 @@ bool commodity_t::history_t::remove_price(const datetime_t& date) void commodity_t::varied_history_t:: add_price(commodity_t& source, - const datetime_t& date, - const amount_t& price, - const bool reflexive) + const datetime_t& date, + const amount_t& price, + const bool reflexive) { optional<history_t&> hist = history(price.commodity()); if (! hist) { std::pair<history_by_commodity_map::iterator, bool> result = histories.insert(history_by_commodity_map::value_type - (&price.commodity(), history_t())); + (&price.commodity(), history_t())); assert(result.second); hist = (*result.first).second; @@ -100,7 +100,7 @@ void commodity_t::varied_history_t:: } bool commodity_t::varied_history_t::remove_price(const datetime_t& date, - commodity_t& comm) + commodity_t& comm) { DEBUG("commodity.prices.add", "varied_remove_price: " << date << ", " << comm); @@ -111,21 +111,21 @@ bool commodity_t::varied_history_t::remove_price(const datetime_t& date, optional<price_point_t> commodity_t::history_t::find_price(const optional<datetime_t>& moment, - const optional<datetime_t>& oldest + const optional<datetime_t>& oldest #if defined(DEBUG_ON) - , const int indent + , const int indent #endif - ) const + ) const { price_point_t point; bool found = false; #if defined(DEBUG_ON) -#define DEBUG_INDENT(cat, indent) \ - do { \ - if (SHOW_DEBUG(cat)) \ - for (int i = 0; i < indent; i++) \ - ledger::_log_buffer << " "; \ +#define DEBUG_INDENT(cat, indent) \ + do { \ + if (SHOW_DEBUG(cat)) \ + for (int i = 0; i < indent; i++) \ + ledger::_log_buffer << " "; \ } while (false) #else #define DEBUG_INDENT(cat, indent) @@ -171,15 +171,15 @@ commodity_t::history_t::find_price(const optional<datetime_t>& moment, } else { point.when = (*i).first; if (*moment < point.when) { - if (i != prices.begin()) { - --i; - point.when = (*i).first; - point.price = (*i).second; - found = true; - } + if (i != prices.begin()) { + --i; + point.when = (*i).first; + point.price = (*i).second; + found = true; + } } else { - point.price = (*i).second; - found = true; + point.price = (*i).second; + found = true; } DEBUG_INDENT("commodity.prices.find", indent); @@ -205,23 +205,23 @@ commodity_t::history_t::find_price(const optional<datetime_t>& moment, else { DEBUG_INDENT("commodity.prices.find", indent); DEBUG("commodity.prices.find", - "returning price: " << point.when << ", " << point.price); + "returning price: " << point.when << ", " << point.price); return point; } } optional<price_point_t> commodity_t::varied_history_t::find_price(const commodity_t& source, - const optional<commodity_t&>& commodity, - const optional<datetime_t>& moment, - const optional<datetime_t>& oldest + const optional<commodity_t&>& commodity, + const optional<datetime_t>& moment, + const optional<datetime_t>& oldest #if defined(DEBUG_ON) - , const int indent + , const int indent #endif - ) const + ) const { optional<price_point_t> point; - optional<datetime_t> limit = oldest; + optional<datetime_t> limit = oldest; #if defined(VERIFY_ON) if (commodity) { @@ -266,61 +266,61 @@ commodity_t::varied_history_t::find_price(const commodity_t& source, DEBUG_INDENT("commodity.prices.find", indent + 1); DEBUG("commodity.prices.find", - "searching for price via commodity '" << comm << "'"); + "searching for price via commodity '" << comm << "'"); point = hist.second.find_price(moment, limit #if defined(DEBUG_ON) - , indent + 2 + , indent + 2 #endif - ); + ); assert(! point || point->price.commodity() == comm); if (point) { optional<price_point_t> xlat; if (commodity && comm != *commodity) { - DEBUG_INDENT("commodity.prices.find", indent + 1); - DEBUG("commodity.prices.find", "looking for translation price"); + DEBUG_INDENT("commodity.prices.find", indent + 1); + DEBUG("commodity.prices.find", "looking for translation price"); - xlat = comm.find_price(commodity, moment, limit, true + xlat = comm.find_price(commodity, moment, limit, true #if defined(DEBUG_ON) - , indent + 2 + , indent + 2 #endif - ); - if (xlat) { - DEBUG_INDENT("commodity.prices.find", indent + 1); - DEBUG("commodity.prices.find", "found translated price " - << xlat->price << " from " << xlat->when); - - point->price = xlat->price * point->price; - if (xlat->when < point->when) { - point->when = xlat->when; - - DEBUG_INDENT("commodity.prices.find", indent + 1); - DEBUG("commodity.prices.find", - "adjusting date of result back to " << point->when); - } - } else { - DEBUG_INDENT("commodity.prices.find", indent + 1); - DEBUG("commodity.prices.find", "saw no translated price there"); - continue; - } + ); + if (xlat) { + DEBUG_INDENT("commodity.prices.find", indent + 1); + DEBUG("commodity.prices.find", "found translated price " + << xlat->price << " from " << xlat->when); + + point->price = xlat->price * point->price; + if (xlat->when < point->when) { + point->when = xlat->when; + + DEBUG_INDENT("commodity.prices.find", indent + 1); + DEBUG("commodity.prices.find", + "adjusting date of result back to " << point->when); + } + } else { + DEBUG_INDENT("commodity.prices.find", indent + 1); + DEBUG("commodity.prices.find", "saw no translated price there"); + continue; + } } assert(! commodity || point->price.commodity() == *commodity); DEBUG_INDENT("commodity.prices.find", indent + 1); DEBUG("commodity.prices.find", - "saw a price there: " << point->price << " from " << point->when); + "saw a price there: " << point->price << " from " << point->when); if (! limit || point->when > *limit) { - limit = point->when; - best = *point; - found = true; + limit = point->when; + best = *point; + found = true; - DEBUG_INDENT("commodity.prices.find", indent + 1); - DEBUG("commodity.prices.find", - "search limit adjusted to " << *limit); + DEBUG_INDENT("commodity.prices.find", indent + 1); + DEBUG("commodity.prices.find", + "search limit adjusted to " << *limit); } } else { DEBUG_INDENT("commodity.prices.find", indent + 1); @@ -331,7 +331,7 @@ commodity_t::varied_history_t::find_price(const commodity_t& source, if (found) { DEBUG_INDENT("commodity.prices.find", indent); DEBUG("commodity.download", - "found price " << best.price << " from " << best.when); + "found price " << best.price << " from " << best.when); return best; } return none; @@ -358,13 +358,13 @@ commodity_t::varied_history_t::history(const optional<commodity_t&>& commodity) optional<price_point_t> commodity_t::find_price(const optional<commodity_t&>& commodity, - const optional<datetime_t>& moment, - const optional<datetime_t>& oldest, - const bool nested + const optional<datetime_t>& moment, + const optional<datetime_t>& oldest, + const bool nested #if defined(DEBUG_ON) - , const int indent + , const int indent #endif - ) const + ) const { if (! has_flags(COMMODITY_WALKED) && base->varied_history) { optional<base_t::time_and_commodity_t> pair; @@ -375,26 +375,26 @@ commodity_t::find_price(const optional<commodity_t&>& commodity, if (! nested) { pair = base_t::time_and_commodity_t - (base_t::optional_time_pair_t(moment, oldest), - commodity ? &(*commodity) : NULL); + (base_t::optional_time_pair_t(moment, oldest), + commodity ? &(*commodity) : NULL); DEBUG_INDENT("commodity.prices.find", indent); DEBUG("commodity.prices.find", "looking for memoized args: " - << (moment ? format_datetime(*moment) : "NONE") << ", " - << (oldest ? format_datetime(*oldest) : "NONE") << ", " - << (commodity ? commodity->symbol() : "NONE")); + << (moment ? format_datetime(*moment) : "NONE") << ", " + << (oldest ? format_datetime(*oldest) : "NONE") << ", " + << (commodity ? commodity->symbol() : "NONE")); base_t::memoized_price_map::iterator i = base->price_map.find(*pair); if (i != base->price_map.end()) { - DEBUG_INDENT("commodity.prices.find", indent); - DEBUG("commodity.prices.find", "found! returning: " - << ((*i).second ? (*i).second->price : amount_t(0L))); + DEBUG_INDENT("commodity.prices.find", indent); + DEBUG("commodity.prices.find", "found! returning: " + << ((*i).second ? (*i).second->price : amount_t(0L))); #if defined(VERIFY_ON) - IF_VERIFY() { - found = true; - checkpoint = (*i).second; - } else + IF_VERIFY() { + found = true; + checkpoint = (*i).second; + } else #endif // defined(VERIFY_ON) - return (*i).second; + return (*i).second; } } @@ -406,11 +406,11 @@ commodity_t::find_price(const optional<commodity_t&>& commodity, DEBUG("commodity.prices.find", "manually finding price..."); point = base->varied_history->find_price(*this, commodity, - moment, oldest + moment, oldest #if defined(DEBUG_ON) - , indent + , indent #endif - ); + ); } catch (...) { const_cast<commodity_t&>(*this).drop_flags(COMMODITY_WALKED); @@ -427,19 +427,19 @@ commodity_t::find_price(const optional<commodity_t&>& commodity, if (! nested && pair) { if (base->price_map.size() > base_t::max_price_map_size) { - DEBUG_INDENT("commodity.prices.find", indent); - DEBUG("commodity.prices.find", - "price map has grown too large, clearing it by half"); + DEBUG_INDENT("commodity.prices.find", indent); + DEBUG("commodity.prices.find", + "price map has grown too large, clearing it by half"); - for (std::size_t i = 0; i < base_t::max_price_map_size >> 1; i++) - base->price_map.erase(base->price_map.begin()); + for (std::size_t i = 0; i < base_t::max_price_map_size >> 1; i++) + base->price_map.erase(base->price_map.begin()); } DEBUG_INDENT("commodity.prices.find", indent); DEBUG("commodity.prices.find", - "remembered: " << (point ? point->price : amount_t(0L))); + "remembered: " << (point ? point->price : amount_t(0L))); base->price_map.insert - (base_t::memoized_price_map::value_type(*pair, point)); + (base_t::memoized_price_map::value_type(*pair, point)); } return point; } @@ -448,8 +448,8 @@ commodity_t::find_price(const optional<commodity_t&>& commodity, optional<price_point_t> commodity_t::check_for_updated_price(const optional<price_point_t>& point, - const optional<datetime_t>& moment, - const optional<commodity_t&>& in_terms_of) + const optional<datetime_t>& moment, + const optional<commodity_t&>& in_terms_of) { if (pool().get_quotes && ! has_flags(COMMODITY_NOMARKET)) { bool exceeds_leeway = true; @@ -457,28 +457,28 @@ commodity_t::check_for_updated_price(const optional<price_point_t>& point, if (point) { time_duration_t::sec_type seconds_diff; if (moment) { - seconds_diff = (*moment - point->when).total_seconds(); - DEBUG("commodity.download", "moment = " << *moment); - DEBUG("commodity.download", "slip.moment = " << seconds_diff); + seconds_diff = (*moment - point->when).total_seconds(); + DEBUG("commodity.download", "moment = " << *moment); + DEBUG("commodity.download", "slip.moment = " << seconds_diff); } else { - seconds_diff = (TRUE_CURRENT_TIME() - point->when).total_seconds(); - DEBUG("commodity.download", "slip.now = " << seconds_diff); + seconds_diff = (TRUE_CURRENT_TIME() - point->when).total_seconds(); + DEBUG("commodity.download", "slip.now = " << seconds_diff); } DEBUG("commodity.download", "leeway = " << pool().quote_leeway); if (seconds_diff < pool().quote_leeway) - exceeds_leeway = false; + exceeds_leeway = false; } if (exceeds_leeway) { DEBUG("commodity.download", - "attempting to download a more current quote..."); + "attempting to download a more current quote..."); if (optional<price_point_t> quote = - pool().get_commodity_quote(*this, in_terms_of)) { - if (! in_terms_of || - (quote->price.has_commodity() && - quote->price.commodity() == *in_terms_of)) - return quote; + pool().get_commodity_quote(*this, in_terms_of)) { + if (! in_terms_of || + (quote->price.has_commodity() && + quote->price.commodity() == *in_terms_of)) + return quote; } } } @@ -568,43 +568,43 @@ void commodity_t::parse_symbol(std::istream& in, string& symbol) while (_p - buf < 255 && in.good() && ! in.eof() && c != '\n') { std::size_t bytes = 0; std::ptrdiff_t size = _p - buf; - unsigned char d = c; + unsigned char d = c; // Check for the start of a UTF-8 multi-byte encoded string if (d >= 192 && d <= 223 && size < 254) - bytes = 2; + bytes = 2; else if (d >= 224 && d <= 239 && size < 253) - bytes = 3; + bytes = 3; else if (d >= 240 && d <= 247 && size < 252) - bytes = 4; + bytes = 4; else if (d >= 248 && d <= 251 && size < 251) - bytes = 5; + bytes = 5; else if (d >= 252 && d <= 253 && size < 250) - bytes = 6; + bytes = 6; else if (d >= 254) // UTF-8 encoding error - break; - - if (bytes > 0) { // we're looking at a UTF-8 encoding - for (std::size_t i = 0; i < bytes; i++) { - in.get(c); - if (in.bad() || in.eof()) - throw_(amount_error, _("Invalid UTF-8 encoding for commodity name")); - *_p++ = c; - } + break; + + if (bytes > 0) { // we're looking at a UTF-8 encoding + for (std::size_t i = 0; i < bytes; i++) { + in.get(c); + if (in.bad() || in.eof()) + throw_(amount_error, _("Invalid UTF-8 encoding for commodity name")); + *_p++ = c; + } } else if (invalid_chars[static_cast<unsigned char>(c)]) { - break; + break; } else { - in.get(c); - if (in.eof()) - break; - if (c == '\\') { - in.get(c); - if (in.eof()) - throw_(amount_error, _("Backslash at end of commodity name")); - } - *_p++ = c; + in.get(c); + if (in.eof()) + break; + if (c == '\\') { + in.get(c); + if (in.eof()) + throw_(amount_error, _("Backslash at end of commodity name")); + } + *_p++ = c; } c = static_cast<char>(in.peek()); @@ -657,7 +657,7 @@ bool commodity_t::valid() const { if (symbol().empty() && this != pool().null_commodity) { DEBUG("ledger.validate", - "commodity_t: symbol().empty() && this != null_commodity"); + "commodity_t: symbol().empty() && this != null_commodity"); return false; } @@ -675,7 +675,7 @@ bool commodity_t::valid() const } bool commodity_t::compare_by_commodity::operator()(const amount_t * left, - const amount_t * right) const + const amount_t * right) const { commodity_t& leftcomm(left->commodity()); commodity_t& rightcomm(right->commodity()); @@ -707,14 +707,14 @@ bool commodity_t::compare_by_commodity::operator()(const amount_t * left, amount_t rightprice(*arightcomm.details.price); if (leftprice.commodity() == rightprice.commodity()) { - return (leftprice - rightprice).sign() < 0; + return (leftprice - rightprice).sign() < 0; } else { - // Since we have two different amounts, there's really no way - // to establish a true sorting order; we'll just do it based - // on the numerical values. - leftprice.clear_commodity(); - rightprice.clear_commodity(); - return (leftprice - rightprice).sign() < 0; + // Since we have two different amounts, there's really no way + // to establish a true sorting order; we'll just do it based + // on the numerical values. + leftprice.clear_commodity(); + rightprice.clear_commodity(); + return (leftprice - rightprice).sign() < 0; } } @@ -725,7 +725,7 @@ bool commodity_t::compare_by_commodity::operator()(const amount_t * left, if (aleftcomm.details.date && arightcomm.details.date) { gregorian::date_duration diff = - *aleftcomm.details.date - *arightcomm.details.date; + *aleftcomm.details.date - *arightcomm.details.date; return diff.is_negative(); } @@ -743,7 +743,7 @@ bool commodity_t::compare_by_commodity::operator()(const amount_t * left, } void to_xml(std::ostream& out, const commodity_t& comm, - bool commodity_details) + bool commodity_details) { push_xml x(out, "commodity", true); @@ -769,21 +769,21 @@ void to_xml(std::ostream& out, const commodity_t& comm, push_xml y(out, "varied-history"); foreach (const commodity_t::history_by_commodity_map::value_type& pair, - comm.varied_history()->histories) { - { - push_xml z(out, "symbol"); - out << y.guard(pair.first->symbol()); - } - { - push_xml z(out, "history"); - - foreach (const commodity_t::history_map::value_type& inner_pair, - pair.second.prices) { - push_xml w(out, "price-point"); - to_xml(out, inner_pair.first); - to_xml(out, inner_pair.second); - } - } + comm.varied_history()->histories) { + { + push_xml z(out, "symbol"); + out << y.guard(pair.first->symbol()); + } + { + push_xml z(out, "history"); + + foreach (const commodity_t::history_map::value_type& inner_pair, + pair.second.prices) { + push_xml w(out, "price-point"); + to_xml(out, inner_pair.first); + to_xml(out, inner_pair.second); + } + } } } } diff --git a/src/commodity.h b/src/commodity.h index 42f15f33..f2275d0e 100644 --- a/src/commodity.h +++ b/src/commodity.h @@ -92,19 +92,19 @@ public: { history_map prices; - void add_price(commodity_t& source, - const datetime_t& date, - const amount_t& price, - const bool reflexive = true); + void add_price(commodity_t& source, + const datetime_t& date, + const amount_t& price, + const bool reflexive = true); bool remove_price(const datetime_t& date); optional<price_point_t> find_price(const optional<datetime_t>& moment = none, - const optional<datetime_t>& oldest = none + const optional<datetime_t>& oldest = none #if defined(DEBUG_ON) - , const int indent = 0 + , const int indent = 0 #endif - ) const; + ) const; #if defined(HAVE_BOOST_SERIALIZATION) private: @@ -125,21 +125,21 @@ public: { history_by_commodity_map histories; - void add_price(commodity_t& source, - const datetime_t& date, - const amount_t& price, - const bool reflexive = true); + void add_price(commodity_t& source, + const datetime_t& date, + const amount_t& price, + const bool reflexive = true); bool remove_price(const datetime_t& date, commodity_t& commodity); optional<price_point_t> - find_price(const commodity_t& source, - const optional<commodity_t&>& commodity = none, - const optional<datetime_t>& moment = none, - const optional<datetime_t>& oldest = none + find_price(const commodity_t& source, + const optional<commodity_t&>& commodity = none, + const optional<datetime_t>& moment = none, + const optional<datetime_t>& oldest = none #if defined(DEBUG_ON) - , const int indent = 0 + , const int indent = 0 #endif - ) const; + ) const; optional<history_t&> history(const optional<commodity_t&>& commodity = none); @@ -169,26 +169,26 @@ protected: #define COMMODITY_STYLE_SEPARATED 0x002 #define COMMODITY_STYLE_DECIMAL_COMMA 0x004 #define COMMODITY_STYLE_THOUSANDS 0x008 -#define COMMODITY_NOMARKET 0x010 -#define COMMODITY_BUILTIN 0x020 -#define COMMODITY_WALKED 0x040 -#define COMMODITY_KNOWN 0x080 -#define COMMODITY_PRIMARY 0x100 +#define COMMODITY_NOMARKET 0x010 +#define COMMODITY_BUILTIN 0x020 +#define COMMODITY_WALKED 0x040 +#define COMMODITY_KNOWN 0x080 +#define COMMODITY_PRIMARY 0x100 - string symbol; + string symbol; amount_t::precision_t precision; - optional<string> name; - optional<string> note; + optional<string> name; + optional<string> note; optional<varied_history_t> varied_history; - optional<amount_t> smaller; - optional<amount_t> larger; + optional<amount_t> smaller; + optional<amount_t> larger; typedef std::pair<optional<datetime_t>, - optional<datetime_t> > optional_time_pair_t; + optional<datetime_t> > optional_time_pair_t; typedef std::pair<optional_time_pair_t, - commodity_t *> time_and_commodity_t; + commodity_t *> time_and_commodity_t; typedef std::map<time_and_commodity_t, - optional<price_point_t> > memoized_price_map; + optional<price_point_t> > memoized_price_map; static const std::size_t max_price_map_size = 16; mutable memoized_price_map price_map; @@ -198,10 +198,10 @@ protected: public: explicit base_t(const string& _symbol) : supports_flags<uint_least16_t> - (commodity_t::decimal_comma_by_default ? - static_cast<uint_least16_t>(COMMODITY_STYLE_DECIMAL_COMMA) : - static_cast<uint_least16_t>(COMMODITY_STYLE_DEFAULTS)), - symbol(_symbol), precision(0), searched(false) { + (commodity_t::decimal_comma_by_default ? + static_cast<uint_least16_t>(COMMODITY_STYLE_DECIMAL_COMMA) : + static_cast<uint_least16_t>(COMMODITY_STYLE_DEFAULTS)), + symbol(_symbol), precision(0), searched(false) { TRACE_CTOR(base_t, "const string&"); } virtual ~base_t() { @@ -237,10 +237,10 @@ protected: commodity_pool_t * parent_; optional<string> qualified_symbol; optional<string> mapping_key_; - bool annotated; + bool annotated; - explicit commodity_t(commodity_pool_t * _parent, - const shared_ptr<base_t>& _base) + explicit commodity_t(commodity_pool_t * _parent, + const shared_ptr<base_t>& _base) : delegates_flags<uint_least16_t>(*_base.get()), base(_base), parent_(_parent), annotated(false) { TRACE_CTOR(commodity_t, "commodity_pool_t *, shared_ptr<base_t>"); @@ -349,36 +349,36 @@ public: // base->varied_history object. void add_price(const datetime_t& date, const amount_t& price, - const bool reflexive = true) { + const bool reflexive = true) { if (! base->varied_history) base->varied_history = varied_history_t(); base->varied_history->add_price(*this, date, price, reflexive); DEBUG("commodity.prices.find", "Price added, clearing price_map"); - base->price_map.clear(); // a price was added, invalid the map + base->price_map.clear(); // a price was added, invalid the map } bool remove_price(const datetime_t& date, commodity_t& commodity) { if (base->varied_history) { base->varied_history->remove_price(date, commodity); DEBUG("commodity.prices.find", "Price removed, clearing price_map"); - base->price_map.clear(); // a price was added, invalid the map + base->price_map.clear(); // a price was added, invalid the map } return false; } optional<price_point_t> find_price(const optional<commodity_t&>& commodity = none, - const optional<datetime_t>& moment = none, - const optional<datetime_t>& oldest = none, - const bool nested = false + const optional<datetime_t>& moment = none, + const optional<datetime_t>& oldest = none, + const bool nested = false #if defined(DEBUG_ON) - , const int indent = 0 + , const int indent = 0 #endif - ) const; + ) const; optional<price_point_t> check_for_updated_price(const optional<price_point_t>& point, - const optional<datetime_t>& moment, - const optional<commodity_t&>& in_terms_of); + const optional<datetime_t>& moment, + const optional<commodity_t&>& in_terms_of); // Methods related to parsing, reading, writing, etc., the commodity // itself. @@ -432,7 +432,7 @@ inline std::ostream& operator<<(std::ostream& out, const commodity_t& comm) { } void to_xml(std::ostream& out, const commodity_t& comm, - bool commodity_details = false); + bool commodity_details = false); } // namespace ledger diff --git a/src/compare.cc b/src/compare.cc index f3c13cea..99e430a7 100644 --- a/src/compare.cc +++ b/src/compare.cc @@ -39,7 +39,7 @@ namespace ledger { void push_sort_value(std::list<sort_value_t>& sort_values, - expr_t::ptr_op_t node, scope_t& scope) + expr_t::ptr_op_t node, scope_t& scope) { if (node->kind == expr_t::op_t::O_CONS) { push_sort_value(sort_values, node->left(), scope); @@ -54,11 +54,11 @@ void push_sort_value(std::list<sort_value_t>& sort_values, sort_values.push_back(sort_value_t()); sort_values.back().inverted = inverted; - sort_values.back().value = expr_t(node).calc(scope).simplified(); + sort_values.back().value = expr_t(node).calc(scope).simplified(); if (sort_values.back().value.is_null()) throw_(calc_error, - _("Could not determine sorting value based an expression")); + _("Could not determine sorting value based an expression")); } } @@ -106,7 +106,7 @@ bool compare_items<account_t>::operator()(account_t * left, account_t * right) } DEBUG("value.sort", "Comparing accounts " << left->fullname() - << " <> " << right->fullname()); + << " <> " << right->fullname()); return sort_value_is_less_than(lxdata.sort_values, rxdata.sort_values); } diff --git a/src/compare.h b/src/compare.h index eeecd7cf..0ba9d424 100644 --- a/src/compare.h +++ b/src/compare.h @@ -50,7 +50,7 @@ class post_t; class account_t; void push_sort_value(std::list<sort_value_t>& sort_values, - expr_t::ptr_op_t node, scope_t& scope); + expr_t::ptr_op_t node, scope_t& scope); template <typename T> class compare_items @@ -84,14 +84,14 @@ bool compare_items<T>::operator()(T * left, T * right) { assert(left); assert(right); return sort_value_is_less_than(find_sort_values(left), - find_sort_values(right)); + find_sort_values(right)); } template <> bool compare_items<post_t>::operator()(post_t * left, post_t * right); template <> bool compare_items<account_t>::operator()(account_t * left, - account_t * right); + account_t * right); } // namespace ledger diff --git a/src/convert.cc b/src/convert.cc index adb82dd4..f33a6b2e 100644 --- a/src/convert.cc +++ b/src/convert.cc @@ -46,8 +46,8 @@ namespace ledger { value_t convert_command(call_scope_t& scope) { interactive_t args(scope, "s"); - report_t& report(find_scope<report_t>(scope)); - journal_t& journal(*report.session.journal.get()); + report_t& report(find_scope<report_t>(scope)); + journal_t& journal(*report.session.journal.get()); string bucket_name; if (report.HANDLED(account_)) @@ -69,16 +69,16 @@ value_t convert_command(call_scope_t& scope) xact_posts_iterator xact_iter(*xact); while ((post = xact_iter()) != NULL) { if (post->account == bucket) - break; + break; } if (post) { post_map_t::iterator i = post_map.find(post->amount); if (i == post_map.end()) { - std::list<post_t *> post_list; - post_list.push_back(post); - post_map.insert(post_map_t::value_type(post->amount, post_list)); + std::list<post_t *> post_list; + post_list.push_back(post); + post_map.insert(post_map_t::value_type(post->amount, post_list)); } else { - (*i).second.push_back(post); + (*i).second.push_back(post); } } } @@ -95,7 +95,7 @@ value_t convert_command(call_scope_t& scope) while (xact_t * xact = reader.read_xact(journal, bucket)) { if (report.HANDLED(invert)) { foreach (post_t * post, xact->posts) - post->amount.in_place_negate(); + post->amount.in_place_negate(); } bool matched = false; @@ -103,46 +103,46 @@ value_t convert_command(call_scope_t& scope) if (i != post_map.end()) { std::list<post_t *>& post_list((*i).second); foreach (post_t * post, post_list) { - if (xact->code && post->xact->code && - *xact->code == *post->xact->code) { - matched = true; - break; - } - else if (xact->actual_date() == post->actual_date()) { - matched = true; - break; - } + if (xact->code && post->xact->code && + *xact->code == *post->xact->code) { + matched = true; + break; + } + else if (xact->actual_date() == post->actual_date()) { + matched = true; + break; + } } } if (matched) { DEBUG("convert.csv", "Ignored xact with code: " << *xact->code); - checked_delete(xact); // ignore it + checked_delete(xact); // ignore it } else { if (xact->posts.front()->account == NULL) { - xacts_iterator xi; - xi.xacts_i = current_xacts.begin(); - xi.xacts_end = current_xacts.end(); - xi.xacts_uninitialized = false; - - // jww (2010-03-07): Bind this logic to an option: --auto-match - if (account_t * acct = - lookup_probable_account(xact->payee, xi, bucket).second) - xact->posts.front()->account = acct; - else - xact->posts.front()->account = unknown; + xacts_iterator xi; + xi.xacts_i = current_xacts.begin(); + xi.xacts_end = current_xacts.end(); + xi.xacts_uninitialized = false; + + // jww (2010-03-07): Bind this logic to an option: --auto-match + if (account_t * acct = + lookup_probable_account(xact->payee, xi, bucket).second) + xact->posts.front()->account = acct; + else + xact->posts.front()->account = unknown; } if (! journal.add_xact(xact)) { - checked_delete(xact); - throw_(std::runtime_error, - _("Failed to finalize derived transaction (check commodities)")); + checked_delete(xact); + throw_(std::runtime_error, + _("Failed to finalize derived transaction (check commodities)")); } else { - xact_posts_iterator xact_iter(*xact); - while (post_t * post = xact_iter()) - formatter(*post); + xact_posts_iterator xact_iter(*xact); + while (post_t * post = xact_iter()) + formatter(*post); } } } @@ -51,29 +51,29 @@ string csv_reader::read_field(std::istream& in) while (in.good() && ! in.eof()) { in.get(x); if (x == '\\') { - in.get(x); + in.get(x); } else if (x == '"' && in.peek() == '"') { - in.get(x); + in.get(x); } else if (x == c) { - if (x == '|') - in.unget(); - else if (in.peek() == ',') - in.get(c); - break; + if (x == '|') + in.unget(); + else if (in.peek() == ',') + in.get(c); + break; } if (x != '\0') - field += x; + field += x; } } else { while (in.good() && ! in.eof()) { in.get(c); if (c == ',') - break; + break; if (c != '\0') - field += c; + field += c; } } trim(field); @@ -144,7 +144,7 @@ xact_t * csv_reader::read_xact(journal_t& journal, account_t * bucket) xact->set_state(item_t::CLEARED); - xact->pos = position_t(); + xact->pos = position_t(); xact->pos->pathname = "jww (2010-03-05): unknown"; xact->pos->beg_pos = in.tellg(); xact->pos->beg_line = 0; @@ -153,7 +153,7 @@ xact_t * csv_reader::read_xact(journal_t& journal, account_t * bucket) post->xact = xact.get(); #if 0 - post->pos = position_t(); + post->pos = position_t(); post->pos->pathname = pathname; post->pos->beg_pos = line_beg_pos; post->pos->beg_line = linenum; @@ -163,7 +163,7 @@ xact_t * csv_reader::read_xact(journal_t& journal, account_t * bucket) post->set_state(item_t::CLEARED); post->account = NULL; - int n = 0; + int n = 0; amount_t amt; string total; @@ -173,12 +173,12 @@ xact_t * csv_reader::read_xact(journal_t& journal, account_t * bucket) switch (index[n]) { case FIELD_DATE: if (field.empty()) - goto restart; + goto restart; try { - xact->_date = parse_date(field); + xact->_date = parse_date(field); } catch (date_error&) { - goto restart; + goto restart; } break; @@ -188,21 +188,21 @@ xact_t * csv_reader::read_xact(journal_t& journal, account_t * bucket) case FIELD_CODE: if (! field.empty()) - xact->code = field; + xact->code = field; break; case FIELD_PAYEE: { bool found = false; foreach (payee_mapping_t& value, journal.payee_mappings) { - DEBUG("csv.mappings", "Looking for payee mapping: " << value.first); - if (value.first.match(field)) { - xact->payee = value.second; - found = true; - break; - } + DEBUG("csv.mappings", "Looking for payee mapping: " << value.first); + if (value.first.match(field)) { + xact->payee = value.second; + found = true; + break; + } } if (! found) - xact->payee = field; + xact->payee = field; break; } @@ -210,8 +210,8 @@ xact_t * csv_reader::read_xact(journal_t& journal, account_t * bucket) std::istringstream amount_str(field); amt.parse(amount_str, PARSE_NO_REDUCE); if (! amt.has_commodity() && - commodity_pool_t::current_pool->default_commodity) - amt.set_commodity(*commodity_pool_t::current_pool->default_commodity); + commodity_pool_t::current_pool->default_commodity) + amt.set_commodity(*commodity_pool_t::current_pool->default_commodity); post->amount = amt; break; } @@ -220,9 +220,9 @@ xact_t * csv_reader::read_xact(journal_t& journal, account_t * bucket) std::istringstream amount_str(field); amt.parse(amount_str, PARSE_NO_REDUCE); if (! amt.has_commodity() && - commodity_pool_t::current_pool->default_commodity) - amt.set_commodity - (*commodity_pool_t::current_pool->default_commodity); + commodity_pool_t::current_pool->default_commodity) + amt.set_commodity + (*commodity_pool_t::current_pool->default_commodity); post->cost = amt; break; } @@ -237,7 +237,7 @@ xact_t * csv_reader::read_xact(journal_t& journal, account_t * bucket) case FIELD_UNKNOWN: if (! names[n].empty() && ! field.empty()) - xact->set_tag(names[n], field); + xact->set_tag(names[n], string_value(field)); break; } n++; @@ -245,7 +245,7 @@ xact_t * csv_reader::read_xact(journal_t& journal, account_t * bucket) #if 0 xact->set_tag(_("Imported"), - string(format_date(CURRENT_DATE(), FMT_WRITTEN))); + string(format_date(CURRENT_DATE(), FMT_WRITTEN))); xact->set_tag(_("Original"), string(line)); xact->set_tag(_("SHA1"), string(sha1sum(line))); #endif @@ -268,7 +268,7 @@ xact_t * csv_reader::read_xact(journal_t& journal, account_t * bucket) post->xact = xact.get(); #if 0 - post->pos = position_t(); + post->pos = position_t(); post->pos->pathname = pathname; post->pos->beg_pos = line_beg_pos; post->pos->beg_line = linenum; @@ -285,7 +285,7 @@ xact_t * csv_reader::read_xact(journal_t& journal, account_t * bucket) std::istringstream assigned_amount_str(total); amt.parse(assigned_amount_str, PARSE_NO_REDUCE); if (! amt.has_commodity() && - commodity_pool_t::current_pool->default_commodity) + commodity_pool_t::current_pool->default_commodity) amt.set_commodity(*commodity_pool_t::current_pool->default_commodity); post->assigned_amount = amt; } diff --git a/src/draft.cc b/src/draft.cc index 69dc7025..ba78fc42 100644 --- a/src/draft.cc +++ b/src/draft.cc @@ -57,45 +57,45 @@ void draft_t::xact_template_t::dump(std::ostream& out) const if (payee_mask.empty()) out << _("Payee mask: INVALID (template expression will cause an error)") - << std::endl; + << std::endl; else out << _("Payee mask: ") << payee_mask << std::endl; if (posts.empty()) { out << std::endl - << _("<Posting copied from last related transaction>") - << std::endl; + << _("<Posting copied from last related transaction>") + << std::endl; } else { bool has_only_from = true; bool has_only_to = true; foreach (const post_template_t& post, posts) { if (post.from) - has_only_to = false; + has_only_to = false; else - has_only_from = false; + has_only_from = false; } foreach (const post_template_t& post, posts) { straccstream accum; out << std::endl - << ACCUM(accum << _("[Posting \"%1\"]") - << (post.from ? _("from") : _("to"))) - << std::endl; + << ACCUM(accum << _("[Posting \"%1\"]") + << (post.from ? _("from") : _("to"))) + << std::endl; if (post.account_mask) - out << _(" Account mask: ") << *post.account_mask << std::endl; + out << _(" Account mask: ") << *post.account_mask << std::endl; else if (post.from) - out << _(" Account mask: <use last of last related accounts>") << std::endl; + out << _(" Account mask: <use last of last related accounts>") << std::endl; else - out << _(" Account mask: <use first of last related accounts>") << std::endl; + out << _(" Account mask: <use first of last related accounts>") << std::endl; if (post.amount) - out << _(" Amount: ") << *post.amount << std::endl; + out << _(" Amount: ") << *post.amount << std::endl; if (post.cost) - out << _(" Cost: ") << *post.cost_operator - << " " << *post.cost << std::endl; + out << _(" Cost: ") << *post.cost_operator + << " " << *post.cost << std::endl; } } } @@ -104,7 +104,7 @@ void draft_t::parse_args(const value_t& args) { regex date_mask(_("([0-9]+(?:[-/.][0-9]+)?(?:[-/.][0-9]+))?")); smatch what; - bool check_for_date = true; + bool check_for_date = true; tmpl = xact_template_t(); @@ -116,16 +116,16 @@ void draft_t::parse_args(const value_t& args) for (; begin != end; begin++) { if (check_for_date && - regex_match((*begin).to_string(), what, date_mask)) { + regex_match((*begin).to_string(), what, date_mask)) { tmpl->date = parse_date(what[0]); check_for_date = false; } else if (check_for_date && - bool(weekday = string_to_day_of_week(what[0]))) { + bool(weekday = string_to_day_of_week(what[0]))) { short dow = static_cast<short>(*weekday); date_t date = CURRENT_DATE() - date_duration(1); while (date.day_of_week() != dow) - date -= date_duration(1); + date -= date_duration(1); tmpl->date = date; check_for_date = false; } @@ -133,81 +133,80 @@ void draft_t::parse_args(const value_t& args) string arg = (*begin).to_string(); if (arg == "at") { - if (begin == end) - throw std::runtime_error(_("Invalid xact command arguments")); - tmpl->payee_mask = (*++begin).to_string(); + if (begin == end) + throw std::runtime_error(_("Invalid xact command arguments")); + tmpl->payee_mask = (*++begin).to_string(); } else if (arg == "to" || arg == "from") { - if (! post || post->account_mask) { - tmpl->posts.push_back(xact_template_t::post_template_t()); - post = &tmpl->posts.back(); - } - if (begin == end) - throw std::runtime_error(_("Invalid xact command arguments")); - post->account_mask = mask_t((*++begin).to_string()); - post->from = arg == "from"; + if (! post || post->account_mask) { + tmpl->posts.push_back(xact_template_t::post_template_t()); + post = &tmpl->posts.back(); + } + if (begin == end) + throw std::runtime_error(_("Invalid xact command arguments")); + post->account_mask = mask_t((*++begin).to_string()); + post->from = arg == "from"; } else if (arg == "on") { - if (begin == end) - throw std::runtime_error(_("Invalid xact command arguments")); - tmpl->date = parse_date((*++begin).to_string()); - check_for_date = false; + if (begin == end) + throw std::runtime_error(_("Invalid xact command arguments")); + tmpl->date = parse_date((*++begin).to_string()); + check_for_date = false; } else if (arg == "code") { - if (begin == end) - throw std::runtime_error(_("Invalid xact command arguments")); - tmpl->code = (*++begin).to_string(); + if (begin == end) + throw std::runtime_error(_("Invalid xact command arguments")); + tmpl->code = (*++begin).to_string(); } else if (arg == "note") { - if (begin == end) - throw std::runtime_error(_("Invalid xact command arguments")); - tmpl->note = (*++begin).to_string(); + if (begin == end) + throw std::runtime_error(_("Invalid xact command arguments")); + tmpl->note = (*++begin).to_string(); } else if (arg == "rest") { - ; // just ignore this argument + ; // just ignore this argument } else if (arg == "@" || arg == "@@") { - amount_t cost; - post->cost_operator = arg; - if (begin == end) - throw std::runtime_error(_("Invalid xact command arguments")); - arg = (*++begin).to_string(); - if (! cost.parse(arg, PARSE_SOFT_FAIL | PARSE_NO_MIGRATE)) - throw std::runtime_error(_("Invalid xact command arguments")); - post->cost = cost; + amount_t cost; + post->cost_operator = arg; + if (begin == end) + throw std::runtime_error(_("Invalid xact command arguments")); + arg = (*++begin).to_string(); + if (! cost.parse(arg, PARSE_SOFT_FAIL | PARSE_NO_MIGRATE)) + throw std::runtime_error(_("Invalid xact command arguments")); + post->cost = cost; } else { - // Without a preposition, it is either: - // - // A payee, if we have not seen one - // An account or an amount, if we have - // An account if an amount has just been seen - // An amount if an account has just been seen - - if (tmpl->payee_mask.empty()) { - tmpl->payee_mask = arg; - } - else { - amount_t amt; - optional<mask_t> account; - - if (! amt.parse(arg, PARSE_SOFT_FAIL | PARSE_NO_MIGRATE)) - account = mask_t(arg); - - if (! post || - (account && post->account_mask) || - (! account && post->amount)) { - tmpl->posts.push_back(xact_template_t::post_template_t()); - post = &tmpl->posts.back(); - } - - if (account) { - post->from = false; - post->account_mask = account; - } else { - post->amount = amt; - } - } + // Without a preposition, it is either: + // + // A payee, if we have not seen one + // An account or an amount, if we have + // An account if an amount has just been seen + // An amount if an account has just been seen + + if (tmpl->payee_mask.empty()) { + tmpl->payee_mask = arg; + } else { + amount_t amt; + optional<mask_t> account; + + if (! amt.parse(arg, PARSE_SOFT_FAIL | PARSE_NO_MIGRATE)) + account = mask_t(arg); + + if (! post || + (account && post->account_mask) || + (! account && post->amount)) { + tmpl->posts.push_back(xact_template_t::post_template_t()); + post = &tmpl->posts.back(); + } + + if (account) { + post->account_mask = account; + } else { + post->amount = amt; + post = NULL; // an amount concludes this posting + } + } } } } @@ -218,14 +217,14 @@ void draft_t::parse_args(const value_t& args) // A single account at the end of the line is the "from" account if (tmpl->posts.size() > 1 && - tmpl->posts.back().account_mask && ! tmpl->posts.back().amount) + tmpl->posts.back().account_mask && ! tmpl->posts.back().amount) tmpl->posts.back().from = true; foreach (xact_template_t::post_template_t& post, tmpl->posts) { if (post.from) - has_only_to = false; + has_only_to = false; else - has_only_from = false; + has_only_from = false; } if (has_only_from) { @@ -252,28 +251,28 @@ xact_t * draft_t::insert(journal_t& journal) xacts_iterator xi(journal); if (xact_t * xact = lookup_probable_account(tmpl->payee_mask.str(), xi).first) { - DEBUG("derive.xact", "Found payee by lookup: transaction on line " - << xact->pos->beg_line); + DEBUG("draft.xact", "Found payee by lookup: transaction on line " + << xact->pos->beg_line); matching = xact; } else { for (xacts_list::reverse_iterator j = journal.xacts.rbegin(); - j != journal.xacts.rend(); - j++) { + j != journal.xacts.rend(); + j++) { if (tmpl->payee_mask.match((*j)->payee)) { - matching = *j; - DEBUG("derive.xact", - "Found payee match: transaction on line " << (*j)->pos->beg_line); - break; + matching = *j; + DEBUG("draft.xact", + "Found payee match: transaction on line " << (*j)->pos->beg_line); + break; } } } if (! tmpl->date) { added->_date = CURRENT_DATE(); - DEBUG("derive.xact", "Setting date to current date"); + DEBUG("draft.xact", "Setting date to current date"); } else { added->_date = tmpl->date; - DEBUG("derive.xact", "Setting date to template date: " << *tmpl->date); + DEBUG("draft.xact", "Setting date to template date: " << *tmpl->date); } added->set_state(item_t::UNCLEARED); @@ -284,48 +283,48 @@ xact_t * draft_t::insert(journal_t& journal) //added->note = matching->note; #if defined(DEBUG_ON) - DEBUG("derive.xact", "Setting payee from match: " << added->payee); + DEBUG("draft.xact", "Setting payee from match: " << added->payee); //if (added->code) - // DEBUG("derive.xact", "Setting code from match: " << *added->code); + // DEBUG("draft.xact", "Setting code from match: " << *added->code); //if (added->note) - // DEBUG("derive.xact", "Setting note from match: " << *added->note); + // DEBUG("draft.xact", "Setting note from match: " << *added->note); #endif } else { added->payee = tmpl->payee_mask.str(); - DEBUG("derive.xact", "Setting payee from template: " << added->payee); + DEBUG("draft.xact", "Setting payee from template: " << added->payee); } if (tmpl->code) { added->code = tmpl->code; - DEBUG("derive.xact", "Now setting code from template: " << *added->code); + DEBUG("draft.xact", "Now setting code from template: " << *added->code); } if (tmpl->note) { added->note = tmpl->note; - DEBUG("derive.xact", "Now setting note from template: " << *added->note); + DEBUG("draft.xact", "Now setting note from template: " << *added->note); } if (tmpl->posts.empty()) { if (matching) { - DEBUG("derive.xact", "Template had no postings, copying from match"); + DEBUG("draft.xact", "Template had no postings, copying from match"); foreach (post_t * post, matching->posts) { - added->add_post(new post_t(*post)); - added->posts.back()->set_state(item_t::UNCLEARED); + added->add_post(new post_t(*post)); + added->posts.back()->set_state(item_t::UNCLEARED); } } else { throw_(std::runtime_error, - _("No accounts, and no past transaction matching '%1'") - << tmpl->payee_mask); + _("No accounts, and no past transaction matching '%1'") + << tmpl->payee_mask); } } else { - DEBUG("derive.xact", "Template had postings"); + DEBUG("draft.xact", "Template had postings"); bool any_post_has_amount = false; foreach (xact_template_t::post_template_t& post, tmpl->posts) { if (post.amount) { - DEBUG("derive.xact", " and at least one has an amount specified"); - any_post_has_amount = true; - break; + DEBUG("draft.xact", " and at least one has an amount specified"); + any_post_has_amount = true; + break; } } @@ -335,171 +334,171 @@ xact_t * draft_t::insert(journal_t& journal) commodity_t * found_commodity = NULL; if (matching) { - if (post.account_mask) { - DEBUG("derive.xact", - "Looking for matching posting based on account mask"); - - foreach (post_t * x, matching->posts) { - if (post.account_mask->match(x->account->fullname())) { - new_post.reset(new post_t(*x)); - DEBUG("derive.xact", - "Founding posting from line " << x->pos->beg_line); - break; - } - } - } else { - if (post.from) { - for (posts_list::reverse_iterator j = matching->posts.rbegin(); - j != matching->posts.rend(); - j++) { - if ((*j)->must_balance()) { - new_post.reset(new post_t(**j)); - DEBUG("derive.xact", - "Copied last real posting from matching"); - break; - } - } - } else { - for (posts_list::iterator j = matching->posts.begin(); - j != matching->posts.end(); - j++) { - if ((*j)->must_balance()) { - new_post.reset(new post_t(**j)); - DEBUG("derive.xact", - "Copied first real posting from matching"); - break; - } - } - } - } + if (post.account_mask) { + DEBUG("draft.xact", + "Looking for matching posting based on account mask"); + + foreach (post_t * x, matching->posts) { + if (post.account_mask->match(x->account->fullname())) { + new_post.reset(new post_t(*x)); + DEBUG("draft.xact", + "Founding posting from line " << x->pos->beg_line); + break; + } + } + } else { + if (post.from) { + for (posts_list::reverse_iterator j = matching->posts.rbegin(); + j != matching->posts.rend(); + j++) { + if ((*j)->must_balance()) { + new_post.reset(new post_t(**j)); + DEBUG("draft.xact", + "Copied last real posting from matching"); + break; + } + } + } else { + for (posts_list::iterator j = matching->posts.begin(); + j != matching->posts.end(); + j++) { + if ((*j)->must_balance()) { + new_post.reset(new post_t(**j)); + DEBUG("draft.xact", + "Copied first real posting from matching"); + break; + } + } + } + } } if (! new_post.get()) { - new_post.reset(new post_t); - DEBUG("derive.xact", "New posting was NULL, creating a blank one"); + new_post.reset(new post_t); + DEBUG("draft.xact", "New posting was NULL, creating a blank one"); } if (! new_post->account) { - DEBUG("derive.xact", "New posting still needs an account"); + DEBUG("draft.xact", "New posting still needs an account"); - if (post.account_mask) { - DEBUG("derive.xact", "The template has an account mask"); + if (post.account_mask) { + DEBUG("draft.xact", "The template has an account mask"); - account_t * acct = NULL; - if (! acct) { - acct = journal.find_account_re(post.account_mask->str()); + account_t * acct = NULL; + if (! acct) { + acct = journal.find_account_re(post.account_mask->str()); #if defined(DEBUG_ON) - if (acct) - DEBUG("derive.xact", "Found account as a regular expression"); + if (acct) + DEBUG("draft.xact", "Found account as a regular expression"); #endif - } - if (! acct) { - acct = journal.find_account(post.account_mask->str()); + } + if (! acct) { + acct = journal.find_account(post.account_mask->str()); #if defined(DEBUG_ON) - if (acct) - DEBUG("derive.xact", "Found (or created) account by name"); + if (acct) + DEBUG("draft.xact", "Found (or created) account by name"); #endif - } - - // Find out the default commodity to use by looking at the last - // commodity used in that account - for (xacts_list::reverse_iterator j = journal.xacts.rbegin(); - j != journal.xacts.rend(); - j++) { - foreach (post_t * x, (*j)->posts) { - if (x->account == acct && ! x->amount.is_null()) { - new_post.reset(new post_t(*x)); - DEBUG("derive.xact", - "Found account in journal postings, setting new posting"); - break; - } - } - } - - new_post->account = acct; - DEBUG("derive.xact", - "Set new posting's account to: " << acct->fullname()); - } else { - if (post.from) { - new_post->account = journal.find_account(_("Liabilities:Unknown")); - DEBUG("derive.xact", - "Set new posting's account to: Liabilities:Unknown"); - } else { - new_post->account = journal.find_account(_("Expenses:Unknown")); - DEBUG("derive.xact", - "Set new posting's account to: Expenses:Unknown"); - } - } + } + + // Find out the default commodity to use by looking at the last + // commodity used in that account + for (xacts_list::reverse_iterator j = journal.xacts.rbegin(); + j != journal.xacts.rend(); + j++) { + foreach (post_t * x, (*j)->posts) { + if (x->account == acct && ! x->amount.is_null()) { + new_post.reset(new post_t(*x)); + DEBUG("draft.xact", + "Found account in journal postings, setting new posting"); + break; + } + } + } + + new_post->account = acct; + DEBUG("draft.xact", + "Set new posting's account to: " << acct->fullname()); + } else { + if (post.from) { + new_post->account = journal.find_account(_("Liabilities:Unknown")); + DEBUG("draft.xact", + "Set new posting's account to: Liabilities:Unknown"); + } else { + new_post->account = journal.find_account(_("Expenses:Unknown")); + DEBUG("draft.xact", + "Set new posting's account to: Expenses:Unknown"); + } + } } assert(new_post->account); if (new_post.get() && ! new_post->amount.is_null()) { - found_commodity = &new_post->amount.commodity(); - - if (any_post_has_amount) { - new_post->amount = amount_t(); - DEBUG("derive.xact", "New posting has an amount, but we cleared it"); - } else { - any_post_has_amount = true; - DEBUG("derive.xact", "New posting has an amount, and we're using it"); - } + found_commodity = &new_post->amount.commodity(); + + if (any_post_has_amount) { + new_post->amount = amount_t(); + DEBUG("draft.xact", "New posting has an amount, but we cleared it"); + } else { + any_post_has_amount = true; + DEBUG("draft.xact", "New posting has an amount, and we're using it"); + } } if (post.amount) { - new_post->amount = *post.amount; - DEBUG("derive.xact", "Copied over posting amount"); + new_post->amount = *post.amount; + DEBUG("draft.xact", "Copied over posting amount"); - if (post.from) { - new_post->amount.in_place_negate(); - DEBUG("derive.xact", "Negated new posting amount"); - } + if (post.from) { + new_post->amount.in_place_negate(); + DEBUG("draft.xact", "Negated new posting amount"); + } } if (post.cost) { - if (post.cost->sign() < 0) - throw parse_error(_("A posting's cost may not be negative")); - - post.cost->in_place_unround(); - - if (*post.cost_operator == "@") { - // For the sole case where the cost might be uncommoditized, - // guarantee that the commodity of the cost after multiplication - // is the same as it was before. - commodity_t& cost_commodity(post.cost->commodity()); - *post.cost *= new_post->amount; - post.cost->set_commodity(cost_commodity); - } - else if (new_post->amount.sign() < 0) { - new_post->cost->in_place_negate(); - } - - new_post->cost = *post.cost; - DEBUG("derive.xact", "Copied over posting cost"); + if (post.cost->sign() < 0) + throw parse_error(_("A posting's cost may not be negative")); + + post.cost->in_place_unround(); + + if (*post.cost_operator == "@") { + // For the sole case where the cost might be uncommoditized, + // guarantee that the commodity of the cost after multiplication + // is the same as it was before. + commodity_t& cost_commodity(post.cost->commodity()); + *post.cost *= new_post->amount; + post.cost->set_commodity(cost_commodity); + } + else if (new_post->amount.sign() < 0) { + new_post->cost->in_place_negate(); + } + + new_post->cost = *post.cost; + DEBUG("draft.xact", "Copied over posting cost"); } if (found_commodity && - ! new_post->amount.is_null() && - ! new_post->amount.has_commodity()) { - new_post->amount.set_commodity(*found_commodity); - DEBUG("derive.xact", "Set posting amount commodity to: " - << new_post->amount.commodity()); - - new_post->amount = new_post->amount.rounded(); - DEBUG("derive.xact", - "Rounded posting amount to: " << new_post->amount); + ! new_post->amount.is_null() && + ! new_post->amount.has_commodity()) { + new_post->amount.set_commodity(*found_commodity); + DEBUG("draft.xact", "Set posting amount commodity to: " + << new_post->amount.commodity()); + + new_post->amount = new_post->amount.rounded(); + DEBUG("draft.xact", + "Rounded posting amount to: " << new_post->amount); } added->add_post(new_post.release()); added->posts.back()->account->add_post(added->posts.back()); added->posts.back()->set_state(item_t::UNCLEARED); - DEBUG("derive.xact", "Added new posting to derived entry"); + DEBUG("draft.xact", "Added new posting to derived entry"); } } if (! journal.add_xact(added.get())) throw_(std::runtime_error, - _("Failed to finalize derived transaction (check commodities)")); + _("Failed to finalize derived transaction (check commodities)")); return added.release(); } diff --git a/src/emacs.cc b/src/emacs.cc index 3c8bb256..7abdfd7f 100644 --- a/src/emacs.cc +++ b/src/emacs.cc @@ -42,11 +42,11 @@ void format_emacs_posts::write_xact(xact_t& xact) { if (xact.pos) out << "\"" << xact.pos->pathname << "\" " - << xact.pos->beg_line << " "; + << xact.pos->beg_line << " "; else out << "\"\" " << -1 << " "; - tm when = gregorian::to_tm(xact.date()); + tm when = gregorian::to_tm(xact.date()); std::time_t date = std::mktime(&when); out << "(" << (date / 65536) << " " << (date % 65536) << " 0) "; @@ -86,7 +86,7 @@ void format_emacs_posts::operator()(post_t& post) out << " (" << -1 << " "; out << "\"" << post.reported_account()->fullname() << "\" \"" - << post.amount << "\""; + << post.amount << "\""; switch (post.state()) { case item_t::CLEARED: diff --git a/src/error.cc b/src/error.cc index cfc91ff1..39ac63ea 100644 --- a/src/error.cc +++ b/src/error.cc @@ -43,6 +43,7 @@ std::ostringstream _desc_buffer; string error_context() { string context = _ctxt_buffer.str(); + _ctxt_buffer.clear(); _ctxt_buffer.str(""); return context; } @@ -54,9 +55,9 @@ string file_context(const path& file, const std::size_t line) return buf.str(); } -string line_context(const string& line, - const string::size_type pos, - const string::size_type end_pos) +string line_context(const string& line, + const string::size_type pos, + const string::size_type end_pos) { std::ostringstream buf; buf << " " << line << "\n"; @@ -65,24 +66,24 @@ string line_context(const string& line, buf << " "; if (end_pos == 0) { for (string::size_type i = 0; i < pos; i += 1) - buf << " "; + buf << " "; buf << "^"; } else { for (string::size_type i = 0; i < end_pos; i += 1) { - if (i >= pos) - buf << "^"; - else - buf << " "; + if (i >= pos) + buf << "^"; + else + buf << " "; } } } return buf.str(); } -string source_context(const path& file, - const istream_pos_type pos, - const istream_pos_type end_pos, - const string& prefix) +string source_context(const path& file, + const istream_pos_type pos, + const istream_pos_type end_pos, + const string& prefix) { const std::streamoff len = end_pos - pos; if (! len || file == path("/dev/stdin")) diff --git a/src/error.h b/src/error.h index 0d33f020..b9960b03 100644 --- a/src/error.h +++ b/src/error.h @@ -51,52 +51,54 @@ extern std::ostringstream _desc_buffer; template <typename T> inline void throw_func(const string& message) { + _desc_buffer.clear(); _desc_buffer.str(""); throw T(message); } -#define throw_(cls, msg) \ - ((_desc_buffer << ACCUM(_desc_accum << msg)), \ - _desc_accum.clear(), \ +#define throw_(cls, msg) \ + ((_desc_buffer << ACCUM(_desc_accum << msg)), \ + _desc_accum.clear(), \ throw_func<cls>(_desc_buffer.str())) inline void warning_func(const string& message) { std::cerr << "Warning: " << message << std::endl; + _desc_buffer.clear(); _desc_buffer.str(""); } -#define warning_(msg) \ - ((_desc_buffer << ACCUM(_desc_accum << msg)), \ - _desc_accum.clear(), \ +#define warning_(msg) \ + ((_desc_buffer << ACCUM(_desc_accum << msg)), \ + _desc_accum.clear(), \ warning_func(_desc_buffer.str())) -extern straccstream _ctxt_accum; +extern straccstream _ctxt_accum; extern std::ostringstream _ctxt_buffer; -#define add_error_context(msg) \ - ((long(_ctxt_buffer.tellp()) == 0) ? \ - ((_ctxt_buffer << ACCUM(_ctxt_accum << msg)), \ - _ctxt_accum.clear()) : \ - ((_ctxt_buffer << std::endl << ACCUM(_ctxt_accum << msg)), \ +#define add_error_context(msg) \ + ((long(_ctxt_buffer.tellp()) == 0) ? \ + ((_ctxt_buffer << ACCUM(_ctxt_accum << msg)), \ + _ctxt_accum.clear()) : \ + ((_ctxt_buffer << std::endl << ACCUM(_ctxt_accum << msg)), \ _ctxt_accum.clear())) string error_context(); string file_context(const path& file, std::size_t line); -string line_context(const string& line, - const string::size_type pos = 0, - const string::size_type end_pos = 0); - -string source_context(const path& file, - const istream_pos_type pos, - const istream_pos_type end_pos, - const string& prefix = ""); - -#define DECLARE_EXCEPTION(name, kind) \ - class name : public kind { \ - public: \ - explicit name(const string& why) throw() : kind(why) {} \ - virtual ~name() throw() {} \ +string line_context(const string& line, + const string::size_type pos = 0, + const string::size_type end_pos = 0); + +string source_context(const path& file, + const istream_pos_type pos, + const istream_pos_type end_pos, + const string& prefix = ""); + +#define DECLARE_EXCEPTION(name, kind) \ + class name : public kind { \ + public: \ + explicit name(const string& why) throw() : kind(why) {} \ + virtual ~name() throw() {} \ } } // namespace ledger diff --git a/src/expr.cc b/src/expr.cc index f3a30de6..defa5b79 100644 --- a/src/expr.cc +++ b/src/expr.cc @@ -37,7 +37,7 @@ namespace ledger { void expr_t::parse(std::istream& in, const parse_flags_t& flags, - const optional<string>& original_string) + const optional<string>& original_string) { parser_t parser; istream_pos_type start_pos = in.tellg(); @@ -78,31 +78,36 @@ value_t expr_t::real_calc(scope_t& scope) } catch (const std::exception& err) { if (locus) { - add_error_context(_("While evaluating value expression:")); - add_error_context(op_context(ptr, locus)); - - if (SHOW_INFO()) { - add_error_context(_("The value expression tree was:")); - std::ostringstream buf; - ptr->dump(buf, 0); - - std::istringstream in(buf.str()); - std::ostringstream out; - char linebuf[1024]; - bool first = true; - while (in.good() && ! in.eof()) { - in.getline(linebuf, 1023); - std::streamsize len = in.gcount(); - if (len > 0) { - if (first) - first = false; - else - out << '\n'; - out << " " << linebuf; - } - } - add_error_context(out.str()); - } + string current_context = error_context(); + + add_error_context(_("While evaluating value expression:")); + add_error_context(op_context(ptr, locus)); + + if (SHOW_INFO()) { + add_error_context(_("The value expression tree was:")); + std::ostringstream buf; + ptr->dump(buf, 0); + + std::istringstream in(buf.str()); + std::ostringstream out; + char linebuf[1024]; + bool first = true; + while (in.good() && ! in.eof()) { + in.getline(linebuf, 1023); + std::streamsize len = in.gcount(); + if (len > 0) { + if (first) + first = false; + else + out << '\n'; + out << " " << linebuf; + } + } + add_error_context(out.str()); + } + + if (! current_context.empty()) + add_error_context(current_context); } throw; } @@ -56,7 +56,7 @@ class expr_t : public expr_base_t<value_t> public: class op_t; - typedef intrusive_ptr<op_t> ptr_op_t; + typedef intrusive_ptr<op_t> ptr_op_t; typedef intrusive_ptr<const op_t> const_ptr_op_t; protected: @@ -112,13 +112,13 @@ public: return parse(stream, flags, str); } - virtual void parse(std::istream& in, - const parse_flags_t& flags = PARSE_DEFAULT, - const optional<string>& original_string = none); + virtual void parse(std::istream& in, + const parse_flags_t& flags = PARSE_DEFAULT, + const optional<string>& original_string = none); virtual void compile(scope_t& scope); virtual value_t real_calc(scope_t& scope); - bool is_constant() const; + bool is_constant() const; value_t& constant_value(); const value_t& constant_value() const; bool is_function() const; diff --git a/src/exprbase.h b/src/exprbase.h index 0c096ab4..7eee0398 100644 --- a/src/exprbase.h +++ b/src/exprbase.h @@ -78,7 +78,7 @@ public: protected: scope_t * context; string str; - bool compiled; + bool compiled; virtual result_type real_calc(scope_t& scope) = 0; @@ -117,7 +117,7 @@ public: return str; } void set_text(const string& txt) { - str = txt; + str = txt; compiled = false; } @@ -126,11 +126,11 @@ public: return parse(stream, flags, str); } virtual void parse(std::istream&, - const parse_flags_t& = PARSE_DEFAULT, - const optional<string>& original_string = none) { + const parse_flags_t& = PARSE_DEFAULT, + const optional<string>& original_string = none) { set_text(original_string ? *original_string : "<stream>"); } - + void mark_uncompiled() { compiled = false; } @@ -157,8 +157,8 @@ public: if (! compiled) { #if defined(DEBUG_ON) if (SHOW_DEBUG("expr.compile")) { - DEBUG("expr.compile", "Before compilation:"); - dump(*_log_stream); + DEBUG("expr.compile", "Before compilation:"); + dump(*_log_stream); } #endif // defined(DEBUG_ON) @@ -167,8 +167,8 @@ public: #if defined(DEBUG_ON) if (SHOW_DEBUG("expr.compile")) { - DEBUG("expr.compile", "After compilation:"); - dump(*_log_stream); + DEBUG("expr.compile", "After compilation:"); + dump(*_log_stream); } #endif // defined(DEBUG_ON) } @@ -249,7 +249,7 @@ private: template <typename ResultType> std::ostream& operator<<(std::ostream& out, - const expr_base_t<ResultType>& expr) { + const expr_base_t<ResultType>& expr) { expr.print(out); return out; } diff --git a/src/filters.cc b/src/filters.cc index b818c7d0..86386f58 100644 --- a/src/filters.cc +++ b/src/filters.cc @@ -76,7 +76,7 @@ void post_splitter::operator()(post_t& post) (*i).second.push_back(&post); } else { std::pair<value_to_posts_map::iterator, bool> inserted - = posts_map.insert(value_to_posts_map::value_type(result, posts_list())); + = posts_map.insert(value_to_posts_map::value_type(result, posts_list())); assert(inserted.second); (*inserted.first).second.push_back(&post); } @@ -84,7 +84,7 @@ void post_splitter::operator()(post_t& post) } pass_down_posts::pass_down_posts(post_handler_ptr handler, - posts_iterator& iter) + posts_iterator& iter) : item_handler<post_t>(handler) { TRACE_CTOR(pass_down_posts, "post_handler_ptr, posts_iterator"); @@ -129,16 +129,16 @@ void truncate_xacts::flush() bool print = false; if (head_count) { if (head_count > 0 && i < head_count) - print = true; + print = true; else if (head_count < 0 && i >= - head_count) - print = true; + print = true; } if (! print && tail_count) { if (tail_count > 0 && l - i <= tail_count) - print = true; + print = true; else if (tail_count < 0 && l - i > - tail_count) - print = true; + print = true; } if (print) @@ -173,7 +173,7 @@ void truncate_xacts::operator()(post_t& post) void sort_posts::post_accumulated_posts() { std::stable_sort(posts.begin(), posts.end(), - compare_items<post_t>(sort_order)); + compare_items<post_t>(sort_order)); foreach (post_t * post, posts) { post->xdata().drop_flags(POST_EXT_SORT_CALC); @@ -185,30 +185,30 @@ void sort_posts::post_accumulated_posts() namespace { void split_string(const string& str, const char ch, - std::list<string>& strings) + std::list<string>& strings) { const char * b = str.c_str(); for (const char * p = b; *p; p++) { if (*p == ch) { - strings.push_back(string(b, p - b)); - b = p + 1; + strings.push_back(string(b, p - b)); + b = p + 1; } } strings.push_back(string(b)); } account_t * create_temp_account_from_path(std::list<string>& account_names, - temporaries_t& temps, - account_t * master) + temporaries_t& temps, + account_t * master) { account_t * new_account = NULL; foreach (const string& name, account_names) { if (new_account) { - new_account = new_account->find_account(name); + new_account = new_account->find_account(name); } else { - new_account = master->find_account(name, false); - if (! new_account) - new_account = &temps.create_account(name, master); + new_account = master->find_account(name, false); + if (! new_account) + new_account = &temps.create_account(name, master); } } @@ -243,7 +243,7 @@ void anonymize_posts::render_commodity(amount_t& amt) if (amt.has_annotation()) amt.set_commodity (*commodity_pool_t::current_pool->find_or_create(buf.str(), - amt.annotation())); + amt.annotation())); else amt.set_commodity (*commodity_pool_t::current_pool->find_or_create(buf.str())); @@ -256,9 +256,9 @@ void anonymize_posts::render_commodity(amount_t& amt) void anonymize_posts::operator()(post_t& post) { - SHA1 sha; + SHA1 sha; uint_least32_t message_digest[5]; - bool copy_xact_details = false; + bool copy_xact_details = false; if (last_xact != post.xact) { temps.copy_xact(*post.xact); @@ -270,8 +270,12 @@ void anonymize_posts::operator()(post_t& post) if (copy_xact_details) { xact.copy_details(*post.xact); + std::ostringstream buf; + buf << reinterpret_cast<uintmax_t>(post.xact->payee.c_str()) + << integer_gen() << post.xact->payee.c_str(); + sha.Reset(); - sha << post.xact->payee.c_str(); + sha << buf.str().c_str(); sha.Result(message_digest); xact.payee = to_hex(message_digest); @@ -283,8 +287,11 @@ void anonymize_posts::operator()(post_t& post) for (account_t * acct = post.account; acct; acct = acct->parent) { + std::ostringstream buf; + buf << integer_gen() << acct << acct->fullname(); + sha.Reset(); - sha << acct->name.c_str(); + sha << buf.str().c_str(); sha.Result(message_digest); account_names.push_front(to_hex(message_digest)); @@ -296,9 +303,7 @@ void anonymize_posts::operator()(post_t& post) temp.note = none; temp.add_flags(POST_ANONYMIZED); - DEBUG("foo", "1.rendering amount: " << temp.amount); render_commodity(temp.amount); - DEBUG("foo", "2.rendering amount: " << temp.amount); if (temp.amount.has_annotation()) { temp.amount.annotation().tag = none; if (temp.amount.annotation().price) @@ -342,15 +347,15 @@ void calc_posts::operator()(post_t& post) namespace { void handle_value(const value_t& value, - account_t * account, - xact_t * xact, - temporaries_t& temps, - post_handler_ptr handler, - const date_t& date = date_t(), - const bool act_date_p = true, - const value_t& total = value_t(), - const bool direct_amount = false, - const bool mark_visited = false) + account_t * account, + xact_t * xact, + temporaries_t& temps, + post_handler_ptr handler, + const date_t& date = date_t(), + const bool act_date_p = true, + const value_t& total = value_t(), + const bool direct_amount = false, + const bool mark_visited = false) { post_t& post = temps.create_post(*xact, account); post.add_flags(ITEM_GENERATED); @@ -359,11 +364,11 @@ namespace { // such. This allows subtotal reports to show "(Account)" for accounts // that contain only virtual posts. if (account && account->has_xdata() && - account->xdata().has_flags(ACCOUNT_EXT_AUTO_VIRTUALIZE)) { + account->xdata().has_flags(ACCOUNT_EXT_AUTO_VIRTUALIZE)) { if (! account->xdata().has_flags(ACCOUNT_EXT_HAS_NON_VIRTUALS)) { - post.add_flags(POST_VIRTUAL); - if (! account->xdata().has_flags(ACCOUNT_EXT_HAS_UNB_VIRTUALS)) - post.add_flags(POST_MUST_BALANCE); + post.add_flags(POST_VIRTUAL); + if (! account->xdata().has_flags(ACCOUNT_EXT_HAS_UNB_VIRTUALS)) + post.add_flags(POST_MUST_BALANCE); } } @@ -371,9 +376,9 @@ namespace { if (is_valid(date)) { if (act_date_p) - xdata.date = date; + xdata.date = date; else - xdata.value_date = date; + xdata.value_date = date; } value_t temp(value); @@ -442,29 +447,29 @@ void collapse_posts::report_subtotal() date_t latest_date; foreach (post_t * post, component_posts) { - date_t date = post->date(); + date_t date = post->date(); date_t value_date = post->value_date(); if (! is_valid(earliest_date) || date < earliest_date) - earliest_date = date; + earliest_date = date; if (! is_valid(latest_date) || value_date > latest_date) - latest_date = value_date; + latest_date = value_date; } xact_t& xact = temps.create_xact(); - xact.payee = last_xact->payee; - xact._date = (is_valid(earliest_date) ? - earliest_date : last_xact->_date); + xact.payee = last_xact->payee; + xact._date = (is_valid(earliest_date) ? + earliest_date : last_xact->_date); DEBUG("filters.collapse", "Pseudo-xact date = " << *xact._date); DEBUG("filters.collapse", "earliest date = " << earliest_date); DEBUG("filters.collapse", "latest date = " << latest_date); handle_value(/* value= */ subtotal, - /* account= */ &totals_account, - /* xact= */ &xact, - /* temps= */ temps, - /* handler= */ handler, - /* date= */ latest_date, - /* act_date_p= */ false); + /* account= */ &totals_account, + /* xact= */ &xact, + /* temps= */ temps, + /* handler= */ handler, + /* date= */ latest_date, + /* act_date_p= */ false); } component_posts.clear(); @@ -497,26 +502,26 @@ void related_posts::flush() if (posts.size() > 0) { foreach (post_t * post, posts) { if (post->xact) { - foreach (post_t * r_post, post->xact->posts) { - post_t::xdata_t& xdata(r_post->xdata()); - if (! xdata.has_flags(POST_EXT_HANDLED) && - (! xdata.has_flags(POST_EXT_RECEIVED) ? - ! r_post->has_flags(ITEM_GENERATED | POST_VIRTUAL) : - also_matching)) { - xdata.add_flags(POST_EXT_HANDLED); - item_handler<post_t>::operator()(*r_post); - } - } + foreach (post_t * r_post, post->xact->posts) { + post_t::xdata_t& xdata(r_post->xdata()); + if (! xdata.has_flags(POST_EXT_HANDLED) && + (! xdata.has_flags(POST_EXT_RECEIVED) ? + ! r_post->has_flags(ITEM_GENERATED | POST_VIRTUAL) : + also_matching)) { + xdata.add_flags(POST_EXT_HANDLED); + item_handler<post_t>::operator()(*r_post); + } + } } else { - // This code should only be reachable from the "output" - // command, since that is the only command which attempts to - // output auto or period xacts. - post_t::xdata_t& xdata(post->xdata()); - if (! xdata.has_flags(POST_EXT_HANDLED) && - ! post->has_flags(ITEM_GENERATED)) { - xdata.add_flags(POST_EXT_HANDLED); - item_handler<post_t>::operator()(*post); - } + // This code should only be reachable from the "output" + // command, since that is the only command which attempts to + // output auto or period xacts. + post_t::xdata_t& xdata(post->xdata()); + if (! xdata.has_flags(POST_EXT_HANDLED) && + ! post->has_flags(ITEM_GENERATED)) { + xdata.add_flags(POST_EXT_HANDLED); + item_handler<post_t>::operator()(*post); + } } } } @@ -525,15 +530,15 @@ void related_posts::flush() } display_filter_posts::display_filter_posts(post_handler_ptr handler, - report_t& _report, - bool _show_rounding) + report_t& _report, + bool _show_rounding) : item_handler<post_t>(handler), report(_report), show_rounding(_show_rounding), rounding_account(temps.create_account(_("<Rounding>"))), revalued_account(temps.create_account(_("<Revalued>"))) { TRACE_CTOR(display_filter_posts, - "post_handler_ptr, report_t&, account_t&, bool"); + "post_handler_ptr, report_t&, account_t&, bool"); display_amount_expr = report.HANDLER(display_amount_).expr; display_total_expr = report.HANDLER(display_total_).expr; @@ -548,7 +553,7 @@ bool display_filter_posts::output_rounding(post_t& post) new_display_total = display_total_expr.calc(bound_scope); DEBUG("filters.changed_value.rounding", - "rounding.new_display_total = " << new_display_total); + "rounding.new_display_total = " << new_display_total); } // Allow the posting to be displayed if: @@ -565,29 +570,29 @@ bool display_filter_posts::output_rounding(post_t& post) if (value_t repriced_amount = display_amount_expr.calc(bound_scope)) { if (! last_display_total.is_null()) { DEBUG("filters.changed_value.rounding", - "rounding.repriced_amount = " << repriced_amount); + "rounding.repriced_amount = " << repriced_amount); value_t precise_display_total(new_display_total.truncated() - - repriced_amount.truncated()); + repriced_amount.truncated()); DEBUG("filters.changed_value.rounding", - "rounding.precise_display_total = " << precise_display_total); + "rounding.precise_display_total = " << precise_display_total); DEBUG("filters.changed_value.rounding", - "rounding.last_display_total = " << last_display_total); + "rounding.last_display_total = " << last_display_total); if (value_t diff = precise_display_total - last_display_total) { - DEBUG("filters.changed_value.rounding", - "rounding.diff = " << diff); - - handle_value(/* value= */ diff, - /* account= */ &rounding_account, - /* xact= */ post.xact, - /* temps= */ temps, - /* handler= */ handler, - /* date= */ date_t(), - /* act_date_p= */ true, - /* total= */ precise_display_total, - /* direct_amount= */ true); + DEBUG("filters.changed_value.rounding", + "rounding.diff = " << diff); + + handle_value(/* value= */ diff, + /* account= */ &rounding_account, + /* xact= */ post.xact, + /* temps= */ temps, + /* handler= */ handler, + /* date= */ date_t(), + /* act_date_p= */ true, + /* total= */ precise_display_total, + /* direct_amount= */ true); } } if (show_rounding) @@ -605,23 +610,23 @@ void display_filter_posts::operator()(post_t& post) } changed_value_posts::changed_value_posts - (post_handler_ptr handler, - report_t& _report, - bool _for_accounts_report, - bool _show_unrealized, + (post_handler_ptr handler, + report_t& _report, + bool _for_accounts_report, + bool _show_unrealized, display_filter_posts * _display_filter) : item_handler<post_t>(handler), report(_report), for_accounts_report(_for_accounts_report), show_unrealized(_show_unrealized), last_post(NULL), revalued_account(_display_filter ? _display_filter->revalued_account : - temps.create_account(_("<Revalued>"))), + temps.create_account(_("<Revalued>"))), display_filter(_display_filter) { TRACE_CTOR(changed_value_posts, "post_handler_ptr, report_t&, bool"); - total_expr = (report.HANDLED(revalued_total_) ? - report.HANDLER(revalued_total_).expr : - report.HANDLER(display_total_).expr); + total_expr = (report.HANDLED(revalued_total_) ? + report.HANDLER(revalued_total_).expr : + report.HANDLER(display_total_).expr); display_total_expr = report.HANDLER(display_total_).expr; changed_values_only = report.HANDLED(revalued_only); @@ -671,51 +676,51 @@ void changed_value_posts::output_revaluation(post_t& post, const date_t& date) post.xdata().date = date_t(); DEBUG("filters.changed_value", - "output_revaluation(last_total) = " << last_total); + "output_revaluation(last_total) = " << last_total); DEBUG("filters.changed_value", - "output_revaluation(repriced_total) = " << repriced_total); + "output_revaluation(repriced_total) = " << repriced_total); if (! last_total.is_null()) { if (value_t diff = repriced_total - last_total) { DEBUG("filters.changed_value", "output_revaluation(strip(diff)) = " - << diff.strip_annotations(report.what_to_keep())); + << diff.strip_annotations(report.what_to_keep())); xact_t& xact = temps.create_xact(); xact.payee = _("Commodities revalued"); xact._date = is_valid(date) ? date : post.value_date(); if (! for_accounts_report) { - handle_value - (/* value= */ diff, - /* account= */ &revalued_account, - /* xact= */ &xact, - /* temps= */ temps, - /* handler= */ handler, - /* date= */ *xact._date, - /* act_date_p= */ true, - /* total= */ repriced_total); + handle_value + (/* value= */ diff, + /* account= */ &revalued_account, + /* xact= */ &xact, + /* temps= */ temps, + /* handler= */ handler, + /* date= */ *xact._date, + /* act_date_p= */ true, + /* total= */ repriced_total); } else if (show_unrealized) { - handle_value - (/* value= */ - diff, - /* account= */ (diff < 0L ? - losses_equity_account : - gains_equity_account), - /* xact= */ &xact, - /* temps= */ temps, - /* handler= */ handler, - /* date= */ *xact._date, - /* act_date_p= */ true, - /* total= */ value_t(), - /* direct_amount= */ false, - /* mark_visited= */ true); + handle_value + (/* value= */ - diff, + /* account= */ (diff < 0L ? + losses_equity_account : + gains_equity_account), + /* xact= */ &xact, + /* temps= */ temps, + /* handler= */ handler, + /* date= */ *xact._date, + /* act_date_p= */ true, + /* total= */ value_t(), + /* direct_amount= */ false, + /* mark_visited= */ true); } } } } -void changed_value_posts::output_intermediate_prices(post_t& post, - const date_t& current) +void changed_value_posts::output_intermediate_prices(post_t& post, + const date_t& current) { // To fix BZ#199, examine the balance of last_post and determine whether the // price of that amount changed after its date and before the new post's @@ -783,24 +788,24 @@ void changed_value_posts::output_intermediate_prices(post_t& post, commodity_t::history_map all_prices; foreach (const balance_t::amounts_map::value_type& amt_comm, - display_total.as_balance().amounts) { + display_total.as_balance().amounts) { if (optional<commodity_t::varied_history_t&> hist = - amt_comm.first->varied_history()) { - foreach - (const commodity_t::history_by_commodity_map::value_type& comm_hist, - hist->histories) { - foreach (const commodity_t::history_map::value_type& price, - comm_hist.second.prices) { - if (price.first.date() > post.value_date() && - price.first.date() < current) { - DEBUG("filters.revalued", post.value_date() << " < " - << price.first.date() << " < " << current); - DEBUG("filters.revalued", "inserting " - << price.second << " at " << price.first.date()); - all_prices.insert(price); - } - } - } + amt_comm.first->varied_history()) { + foreach + (const commodity_t::history_by_commodity_map::value_type& comm_hist, + hist->histories) { + foreach (const commodity_t::history_map::value_type& price, + comm_hist.second.prices) { + if (price.first.date() > post.value_date() && + price.first.date() < current) { + DEBUG("filters.revalued", post.value_date() << " < " + << price.first.date() << " < " << current); + DEBUG("filters.revalued", "inserting " + << price.second << " at " << price.first.date()); + all_prices.insert(price); + } + } + } } } @@ -813,7 +818,7 @@ void changed_value_posts::output_intermediate_prices(post_t& post, // This insert will fail if a later price has already been inserted // for that date. DEBUG("filters.revalued", - "re-inserting " << price.second << " at " << price.first.date()); + "re-inserting " << price.second << " at " << price.first.date()); pricing_dates.insert(date_map::value_type(price.first.date(), true)); } @@ -849,8 +854,8 @@ void changed_value_posts::operator()(post_t& post) last_post = &post; } -void subtotal_posts::report_subtotal(const char * spec_fmt, - const optional<date_interval_t>& interval) +void subtotal_posts::report_subtotal(const char * spec_fmt, + const optional<date_interval_t>& interval) { if (component_posts.empty()) return; @@ -860,12 +865,12 @@ void subtotal_posts::report_subtotal(const char * spec_fmt, if (! range_start || ! range_finish) { foreach (post_t * post, component_posts) { - date_t date = post->date(); + date_t date = post->date(); date_t value_date = post->value_date(); if (! range_start || date < *range_start) - range_start = date; + range_start = date; if (! range_finish || value_date > *range_finish) - range_finish = value_date; + range_finish = value_date; } } component_posts.clear(); @@ -876,7 +881,7 @@ void subtotal_posts::report_subtotal(const char * spec_fmt, } else if (date_format) { out_date << "- " << format_date(*range_finish, FMT_CUSTOM, - date_format->c_str()); + date_format->c_str()); } else { out_date << "- " << format_date(*range_finish); @@ -888,12 +893,12 @@ void subtotal_posts::report_subtotal(const char * spec_fmt, foreach (values_map::value_type& pair, values) handle_value(/* value= */ pair.second.value, - /* account= */ pair.second.account, - /* xact= */ &xact, - /* temps= */ temps, - /* handler= */ handler, - /* date= */ *range_finish, - /* act_date_p= */ false); + /* account= */ pair.second.account, + /* xact= */ &xact, + /* temps= */ temps, + /* handler= */ handler, + /* date= */ *range_finish, + /* act_date_p= */ false); values.clear(); } @@ -952,25 +957,25 @@ void interval_posts::operator()(post_t& post) report_subtotal(last_interval); if (generate_empty_posts) { - for (++last_interval; interval != last_interval; ++last_interval) { - // Generate a null posting, so the intervening periods can be - // seen when -E is used, or if the calculated amount ends up being - // non-zero - xact_t& null_xact = temps.create_xact(); - null_xact._date = last_interval.inclusive_end(); - - post_t& null_post = temps.create_post(null_xact, &empty_account); - null_post.add_flags(POST_CALCULATED); - null_post.amount = 0L; - - last_post = &null_post; - subtotal_posts::operator()(null_post); - - report_subtotal(last_interval); - } - assert(interval == last_interval); + for (++last_interval; interval != last_interval; ++last_interval) { + // Generate a null posting, so the intervening periods can be + // seen when -E is used, or if the calculated amount ends up being + // non-zero + xact_t& null_xact = temps.create_xact(); + null_xact._date = last_interval.inclusive_end(); + + post_t& null_post = temps.create_post(null_xact, &empty_account); + null_post.add_flags(POST_CALCULATED); + null_post.amount = 0L; + + last_post = &null_post; + subtotal_posts::operator()(null_post); + + report_subtotal(last_interval); + } + assert(interval == last_interval); } else { - last_interval = interval; + last_interval = interval; } } else { last_interval = interval; @@ -1001,22 +1006,22 @@ void posts_as_equity::report_subtotal() foreach (values_map::value_type& pair, values) { if (pair.second.value.is_balance()) { foreach (const balance_t::amounts_map::value_type& amount_pair, - pair.second.value.as_balance().amounts) - handle_value(/* value= */ amount_pair.second, - /* account= */ pair.second.account, - /* xact= */ &xact, - /* temps= */ temps, - /* handler= */ handler, - /* date= */ finish, - /* act_date_p= */ false); + pair.second.value.as_balance().amounts) + handle_value(/* value= */ amount_pair.second, + /* account= */ pair.second.account, + /* xact= */ &xact, + /* temps= */ temps, + /* handler= */ handler, + /* date= */ finish, + /* act_date_p= */ false); } else { handle_value(/* value= */ pair.second.value, - /* account= */ pair.second.account, - /* xact= */ &xact, - /* temps= */ temps, - /* handler= */ handler, - /* date= */ finish, - /* act_date_p= */ false); + /* account= */ pair.second.account, + /* xact= */ &xact, + /* temps= */ temps, + /* handler= */ handler, + /* date= */ finish, + /* act_date_p= */ false); } total += pair.second.value; } @@ -1024,7 +1029,7 @@ void posts_as_equity::report_subtotal() if (total.is_balance()) { foreach (const balance_t::amounts_map::value_type& pair, - total.as_balance().amounts) { + total.as_balance().amounts) { post_t& balance_post = temps.create_post(xact, balance_account); balance_post.amount = - pair.second; (*handler)(balance_post); @@ -1052,7 +1057,7 @@ void by_payee_posts::operator()(post_t& post) if (i == payee_subtotals.end()) { payee_subtotals_pair temp(post.xact->payee, - shared_ptr<subtotal_posts>(new subtotal_posts(handler, amount_expr))); + shared_ptr<subtotal_posts>(new subtotal_posts(handler, amount_expr))); std::pair<payee_subtotals_map::iterator, bool> result = payee_subtotals.insert(temp); @@ -1085,22 +1090,22 @@ void transfer_details::operator()(post_t& post) case SET_ACCOUNT: { string account_name = substitute.to_string(); if (! account_name.empty() && - account_name[account_name.length() - 1] != ':') { - account_t * prev_account = temp.account; - temp.account->remove_post(&temp); - - account_name += ':'; - account_name += prev_account->fullname(); - - std::list<string> account_names; - split_string(account_name, ':', account_names); - temp.account = create_temp_account_from_path(account_names, temps, - xact.journal->master); - temp.account->add_post(&temp); - - temp.account->add_flags(prev_account->flags()); - if (prev_account->has_xdata()) - temp.account->xdata().add_flags(prev_account->xdata().flags()); + account_name[account_name.length() - 1] != ':') { + account_t * prev_account = temp.account; + temp.account->remove_post(&temp); + + account_name += ':'; + account_name += prev_account->fullname(); + + std::list<string> account_names; + split_string(account_name, ':', account_names); + temp.account = create_temp_account_from_path(account_names, temps, + xact.journal->master); + temp.account->add_post(&temp); + + temp.account->add_flags(prev_account->flags()); + if (prev_account->has_xdata()) + temp.account->xdata().add_flags(prev_account->xdata().flags()); } break; } @@ -1153,42 +1158,41 @@ void budget_posts::report_budget_items(const date_t& date) foreach (pending_posts_list::value_type& pair, pending_posts) { optional<date_t> begin = pair.first.start; if (! begin) { - if (! pair.first.find_period(date)) - throw_(std::runtime_error, - _("Something odd has happened at date %1") << date); - begin = pair.first.start; + if (! pair.first.find_period(date)) + continue; + begin = pair.first.start; } assert(begin); if (*begin <= date && - (! pair.first.finish || *begin < *pair.first.finish)) { - post_t& post = *pair.second; + (! pair.first.finish || *begin < *pair.first.finish)) { + post_t& post = *pair.second; - DEBUG("budget.generate", "Reporting budget for " - << post.reported_account()->fullname()); + DEBUG("budget.generate", "Reporting budget for " + << post.reported_account()->fullname()); - xact_t& xact = temps.create_xact(); - xact.payee = _("Budget transaction"); - xact._date = begin; + xact_t& xact = temps.create_xact(); + xact.payee = _("Budget transaction"); + xact._date = begin; - post_t& temp = temps.copy_post(post, xact); - temp.amount.in_place_negate(); + post_t& temp = temps.copy_post(post, xact); + temp.amount.in_place_negate(); - if (flags & BUDGET_WRAP_VALUES) { - value_t seq; - seq.push_back(0L); - seq.push_back(temp.amount); + if (flags & BUDGET_WRAP_VALUES) { + value_t seq; + seq.push_back(0L); + seq.push_back(temp.amount); - temp.xdata().compound_value = seq; - temp.xdata().add_flags(POST_EXT_COMPOUND); - } + temp.xdata().compound_value = seq; + temp.xdata().add_flags(POST_EXT_COMPOUND); + } - ++pair.first; - begin = *pair.first.start; + ++pair.first; + begin = *pair.first.start; - item_handler<post_t>::operator()(temp); + item_handler<post_t>::operator()(temp); - reported = true; + reported = true; } } } while (reported); @@ -1200,14 +1204,14 @@ void budget_posts::operator()(post_t& post) foreach (pending_posts_list::value_type& pair, pending_posts) { for (account_t * acct = post.reported_account(); - acct; - acct = acct->parent) { + acct; + acct = acct->parent) { if (acct == (*pair.second).reported_account()) { - post_in_budget = true; - // Report the post as if it had occurred in the parent account. - if (post.reported_account() != acct) - post.set_reported_account(acct); - goto handle; + post_in_budget = true; + // Report the post as if it had occurred in the parent account. + if (post.reported_account() != acct) + post.set_reported_account(acct); + goto handle; } } } @@ -1275,10 +1279,10 @@ void forecast_posts::flush() // period contains the earliest starting date. pending_posts_list::iterator least = pending_posts.begin(); for (pending_posts_list::iterator i = ++pending_posts.begin(); - i != pending_posts.end(); - i++) { + i != pending_posts.end(); + i++) { if (*(*i).first.start < *(*least).first.start) - least = i; + least = i; } date_t& begin = *(*least).first.start; @@ -1294,10 +1298,10 @@ void forecast_posts::flush() assert(next > begin); if (static_cast<std::size_t>((next - last).days()) > - static_cast<std::size_t>(365U) * forecast_years) { + static_cast<std::size_t>(365U) * forecast_years) { DEBUG("filters.forecast", - "Forecast transaction exceeds " << forecast_years - << " years beyond today"); + "Forecast transaction exceeds " << forecast_years + << " years beyond today"); pending_posts.erase(least); continue; } @@ -1310,15 +1314,15 @@ void forecast_posts::flush() // "Forecast transaction". post_t& post = *(*least).second; xact_t& xact = temps.create_xact(); - xact.payee = _("Forecast transaction"); - xact._date = begin; + xact.payee = _("Forecast transaction"); + xact._date = begin; post_t& temp = temps.copy_post(post, xact); // Submit the generated posting DEBUG("filters.forecast", - "Forecast transaction: " << temp.date() - << " " << temp.account->fullname() - << " " << temp.amount); + "Forecast transaction: " << temp.date() + << " " << temp.account->fullname() + << " " << temp.amount); item_handler<post_t>::operator()(temp); // If the generated posting matches the user's report query, check whether @@ -1328,9 +1332,9 @@ void forecast_posts::flush() DEBUG("filters.forecast", " matches report query"); bind_scope_t bound_scope(context, temp); if (! pred(bound_scope)) { - DEBUG("filters.forecast", " fails to match continuation criteria"); - pending_posts.erase(least); - continue; + DEBUG("filters.forecast", " fails to match continuation criteria"); + pending_posts.erase(least); + continue; } } } @@ -1338,10 +1342,10 @@ void forecast_posts::flush() item_handler<post_t>::flush(); } -pass_down_accounts::pass_down_accounts(acct_handler_ptr handler, - accounts_iterator& iter, - const optional<predicate_t>& _pred, - const optional<scope_t&>& _context) +pass_down_accounts::pass_down_accounts(acct_handler_ptr handler, + accounts_iterator& iter, + const optional<predicate_t>& _pred, + const optional<scope_t&>& _context) : item_handler<account_t>(handler), pred(_pred), context(_context) { TRACE_CTOR(pass_down_accounts, "acct_handler_ptr, accounts_iterator, ..."); @@ -1352,7 +1356,7 @@ pass_down_accounts::pass_down_accounts(acct_handler_ptr handler, } else { bind_scope_t bound_scope(*context, *account); if ((*pred)(bound_scope)) - item_handler<account_t>::operator()(*account); + item_handler<account_t>::operator()(*account); } } diff --git a/src/filters.h b/src/filters.h index ffca9d1e..0f414151 100644 --- a/src/filters.h +++ b/src/filters.h @@ -62,17 +62,17 @@ public: typedef function<void (const value_t&)> custom_flusher_t; protected: - value_to_posts_map posts_map; - post_handler_ptr post_chain; - report_t& report; - expr_t group_by_expr; - custom_flusher_t preflush_func; + value_to_posts_map posts_map; + post_handler_ptr post_chain; + report_t& report; + expr_t group_by_expr; + custom_flusher_t preflush_func; optional<custom_flusher_t> postflush_func; public: post_splitter(post_handler_ptr _post_chain, - report_t& _report, - expr_t _group_by_expr) + report_t& _report, + expr_t _group_by_expr) : post_chain(_post_chain), report(_report), group_by_expr(_group_by_expr), preflush_func(bind(&post_splitter::print_title, this, _1)) { @@ -192,7 +192,7 @@ class truncate_xacts : public item_handler<post_t> public: truncate_xacts(post_handler_ptr handler, - int _head_count, int _tail_count) + int _head_count, int _tail_count) : item_handler<post_t>(handler), head_count(_head_count), tail_count(_tail_count), completed(false), xacts_seen(0), last_xact(NULL) { @@ -267,12 +267,12 @@ public: sort_xacts(post_handler_ptr handler, const expr_t& _sort_order) : sorter(handler, _sort_order) { TRACE_CTOR(sort_xacts, - "post_handler_ptr, const value_expr&"); + "post_handler_ptr, const value_expr&"); } sort_xacts(post_handler_ptr handler, const string& _sort_order) : sorter(handler, _sort_order) { TRACE_CTOR(sort_xacts, - "post_handler_ptr, const string&"); + "post_handler_ptr, const string&"); } virtual ~sort_xacts() { TRACE_DTOR(sort_xacts); @@ -308,9 +308,9 @@ class filter_posts : public item_handler<post_t> filter_posts(); public: - filter_posts(post_handler_ptr handler, - const predicate_t& predicate, - scope_t& _context) + filter_posts(post_handler_ptr handler, + const predicate_t& predicate, + scope_t& _context) : item_handler<post_t>(handler), pred(predicate), context(_context) { TRACE_CTOR(filter_posts, "post_handler_ptr, predicate_t, scope_t&"); } @@ -334,18 +334,26 @@ public: class anonymize_posts : public item_handler<post_t> { - typedef std::map<commodity_t *, std::size_t> commodity_index_map; + typedef std::map<commodity_t *, std::size_t> commodity_index_map; + typedef variate_generator<mt19937&, uniform_int<> > int_generator_t; - temporaries_t temps; + temporaries_t temps; commodity_index_map comms; std::size_t next_comm_id; - xact_t * last_xact; + xact_t * last_xact; + mt19937 rnd_gen; + uniform_int<> integer_range; + int_generator_t integer_gen; anonymize_posts(); public: anonymize_posts(post_handler_ptr handler) - : item_handler<post_t>(handler), next_comm_id(0), last_xact(NULL) { + : item_handler<post_t>(handler), next_comm_id(0), last_xact(NULL), + rnd_gen(static_cast<unsigned int>(reinterpret_cast<uintmax_t>(this) + + static_cast<uintmax_t>(std::time(0)))), + integer_range(1, 2000000000L), + integer_gen(rnd_gen, integer_range) { TRACE_CTOR(anonymize_posts, "post_handler_ptr"); } virtual ~anonymize_posts() { @@ -374,8 +382,8 @@ class calc_posts : public item_handler<post_t> public: calc_posts(post_handler_ptr handler, - expr_t& _amount_expr, - bool _calc_running_total = false) + expr_t& _amount_expr, + bool _calc_running_total = false) : item_handler<post_t>(handler), last_post(NULL), amount_expr(_amount_expr), calc_running_total(_calc_running_total) { TRACE_CTOR(calc_posts, "post_handler_ptr, expr_t&, bool"); @@ -396,16 +404,16 @@ public: class collapse_posts : public item_handler<post_t> { - expr_t& amount_expr; - predicate_t display_predicate; - predicate_t only_predicate; - value_t subtotal; - std::size_t count; - xact_t * last_xact; - post_t * last_post; + expr_t& amount_expr; + predicate_t display_predicate; + predicate_t only_predicate; + value_t subtotal; + std::size_t count; + xact_t * last_xact; + post_t * last_post; temporaries_t temps; - account_t& totals_account; - bool only_collapse_if_zero; + account_t& totals_account; + bool only_collapse_if_zero; std::list<post_t *> component_posts; report_t& report; @@ -413,11 +421,11 @@ class collapse_posts : public item_handler<post_t> public: collapse_posts(post_handler_ptr handler, - report_t& _report, - expr_t& _amount_expr, - predicate_t _display_predicate, - predicate_t _only_predicate, - bool _only_collapse_if_zero = false) + report_t& _report, + expr_t& _amount_expr, + predicate_t _display_predicate, + predicate_t _only_predicate, + bool _only_collapse_if_zero = false) : item_handler<post_t>(handler), amount_expr(_amount_expr), display_predicate(_display_predicate), only_predicate(_only_predicate), count(0), @@ -459,17 +467,17 @@ public: class related_posts : public item_handler<post_t> { posts_list posts; - bool also_matching; + bool also_matching; related_posts(); public: related_posts(post_handler_ptr handler, - const bool _also_matching = false) + const bool _also_matching = false) : item_handler<post_t>(handler), also_matching(_also_matching) { TRACE_CTOR(related_posts, - "post_handler_ptr, const bool"); + "post_handler_ptr, const bool"); } virtual ~related_posts() throw() { TRACE_DTOR(related_posts); @@ -492,22 +500,22 @@ class display_filter_posts : public item_handler<post_t> // This filter requires that calc_posts be used at some point // later in the chain. - expr_t display_amount_expr; - expr_t display_total_expr; + expr_t display_amount_expr; + expr_t display_total_expr; report_t& report; - bool show_rounding; - value_t last_display_total; - temporaries_t temps; - account_t& rounding_account; + bool show_rounding; + value_t last_display_total; + temporaries_t temps; + account_t& rounding_account; display_filter_posts(); public: - account_t& revalued_account; + account_t& revalued_account; display_filter_posts(post_handler_ptr handler, - report_t& _report, - bool _show_rounding); + report_t& _report, + bool _show_rounding); virtual ~display_filter_posts() { TRACE_DTOR(display_filter_posts); @@ -534,30 +542,30 @@ class changed_value_posts : public item_handler<post_t> // This filter requires that calc_posts be used at some point // later in the chain. - expr_t total_expr; - expr_t display_total_expr; - report_t& report; - bool changed_values_only; - bool for_accounts_report; - bool show_unrealized; - post_t * last_post; - value_t last_total; + expr_t total_expr; + expr_t display_total_expr; + report_t& report; + bool changed_values_only; + bool for_accounts_report; + bool show_unrealized; + post_t * last_post; + value_t last_total; value_t repriced_total; - temporaries_t temps; - account_t& revalued_account; - account_t * gains_equity_account; - account_t * losses_equity_account; + temporaries_t temps; + account_t& revalued_account; + account_t * gains_equity_account; + account_t * losses_equity_account; display_filter_posts * display_filter; changed_value_posts(); public: - changed_value_posts(post_handler_ptr handler, - report_t& _report, - bool _for_accounts_report, - bool _show_unrealized, - display_filter_posts * _display_filter); + changed_value_posts(post_handler_ptr handler, + report_t& _report, + bool _for_accounts_report, + bool _show_unrealized, + display_filter_posts * _display_filter); virtual ~changed_value_posts() { TRACE_DTOR(changed_value_posts); @@ -593,8 +601,8 @@ protected: acct_value_t(); public: - account_t * account; - value_t value; + account_t * account; + value_t value; acct_value_t(account_t * a) : account(a) { TRACE_CTOR(acct_value_t, "account_t *"); @@ -615,26 +623,26 @@ protected: typedef std::pair<string, acct_value_t> values_pair; protected: - expr_t& amount_expr; - values_map values; + expr_t& amount_expr; + values_map values; optional<string> date_format; temporaries_t temps; std::list<post_t *> component_posts; public: subtotal_posts(post_handler_ptr handler, expr_t& _amount_expr, - const optional<string>& _date_format = none) + const optional<string>& _date_format = none) : item_handler<post_t>(handler), amount_expr(_amount_expr), date_format(_date_format) { TRACE_CTOR(subtotal_posts, - "post_handler_ptr, expr_t&, const optional<string>&"); + "post_handler_ptr, expr_t&, const optional<string>&"); } virtual ~subtotal_posts() { TRACE_DTOR(subtotal_posts); } void report_subtotal(const char * spec_fmt = NULL, - const optional<date_interval_t>& interval = none); + const optional<date_interval_t>& interval = none); virtual void flush() { if (values.size() > 0) @@ -658,27 +666,27 @@ class interval_posts : public subtotal_posts date_interval_t start_interval; date_interval_t interval; date_interval_t last_interval; - post_t * last_post; - account_t& empty_account; - bool exact_periods; - bool generate_empty_posts; + post_t * last_post; + account_t& empty_account; + bool exact_periods; + bool generate_empty_posts; interval_posts(); public: - interval_posts(post_handler_ptr _handler, - expr_t& amount_expr, - const date_interval_t& _interval, - bool _exact_periods = false, - bool _generate_empty_posts = false) + interval_posts(post_handler_ptr _handler, + expr_t& amount_expr, + const date_interval_t& _interval, + bool _exact_periods = false, + bool _generate_empty_posts = false) : subtotal_posts(_handler, amount_expr), start_interval(_interval), interval(start_interval), last_post(NULL), empty_account(temps.create_account(_("<None>"))), exact_periods(_exact_periods), generate_empty_posts(_generate_empty_posts) { TRACE_CTOR(interval_posts, - "post_handler_ptr, expr_t&, date_interval_t, bool, bool"); + "post_handler_ptr, expr_t&, date_interval_t, bool, bool"); } virtual ~interval_posts() throw() { TRACE_DTOR(interval_posts); @@ -689,7 +697,7 @@ public: virtual void flush() { if (last_post && interval.duration) { if (interval.is_valid()) - report_subtotal(interval); + report_subtotal(interval); subtotal_posts::flush(); } } @@ -741,7 +749,7 @@ class by_payee_posts : public item_handler<post_t> typedef std::map<string, shared_ptr<subtotal_posts> > payee_subtotals_map; typedef std::pair<string, shared_ptr<subtotal_posts> > payee_subtotals_pair; - expr_t& amount_expr; + expr_t& amount_expr; payee_subtotals_map payee_subtotals; by_payee_posts(); @@ -768,9 +776,9 @@ class by_payee_posts : public item_handler<post_t> class transfer_details : public item_handler<post_t> { - account_t * master; - expr_t expr; - scope_t& scope; + account_t * master; + expr_t expr; + scope_t& scope; temporaries_t temps; transfer_details(); @@ -783,14 +791,14 @@ public: } which_element; transfer_details(post_handler_ptr handler, - element_t _which_element, - account_t * _master, - const expr_t& _expr, - scope_t& _scope) + element_t _which_element, + account_t * _master, + const expr_t& _expr, + scope_t& _scope) : item_handler<post_t>(handler), master(_master), expr(_expr), scope(_scope), which_element(_which_element) { TRACE_CTOR(transfer_details, - "post_handler_ptr, element_t, account_t *, expr_t, scope_t&"); + "post_handler_ptr, element_t, account_t *, expr_t, scope_t&"); } virtual ~transfer_details() { TRACE_DTOR(transfer_details); @@ -840,7 +848,7 @@ class generate_posts : public item_handler<post_t> protected: typedef std::pair<date_interval_t, post_t *> pending_posts_pair; - typedef std::list<pending_posts_pair> pending_posts_list; + typedef std::list<pending_posts_pair> pending_posts_list; pending_posts_list pending_posts; temporaries_t temps; @@ -870,7 +878,7 @@ public: class budget_posts : public generate_posts { #define BUDGET_NO_BUDGET 0x00 -#define BUDGET_BUDGETED 0x01 +#define BUDGET_BUDGETED 0x01 #define BUDGET_UNBUDGETED 0x02 #define BUDGET_WRAP_VALUES 0x04 @@ -880,7 +888,7 @@ class budget_posts : public generate_posts public: budget_posts(post_handler_ptr handler, - uint_least8_t _flags = BUDGET_BUDGETED) + uint_least8_t _flags = BUDGET_BUDGETED) : generate_posts(handler), flags(_flags) { TRACE_CTOR(budget_posts, "post_handler_ptr, uint_least8_t"); } @@ -895,19 +903,19 @@ public: class forecast_posts : public generate_posts { - predicate_t pred; - scope_t& context; + predicate_t pred; + scope_t& context; const std::size_t forecast_years; public: forecast_posts(post_handler_ptr handler, - const predicate_t& predicate, - scope_t& _context, - const std::size_t _forecast_years) + const predicate_t& predicate, + scope_t& _context, + const std::size_t _forecast_years) : generate_posts(handler), pred(predicate), context(_context), forecast_years(_forecast_years) { TRACE_CTOR(forecast_posts, - "post_handler_ptr, predicate_t, scope_t&, std::size_t"); + "post_handler_ptr, predicate_t, scope_t&, std::size_t"); } virtual ~forecast_posts() throw() { TRACE_DTOR(forecast_posts); @@ -937,10 +945,10 @@ class pass_down_accounts : public item_handler<account_t> optional<scope_t&> context; public: - pass_down_accounts(acct_handler_ptr handler, - accounts_iterator& iter, - const optional<predicate_t>& _pred = none, - const optional<scope_t&>& _context = none); + pass_down_accounts(acct_handler_ptr handler, + accounts_iterator& iter, + const optional<predicate_t>& _pred = none, + const optional<scope_t&>& _context = none); virtual ~pass_down_accounts() { TRACE_DTOR(pass_down_accounts); diff --git a/src/format.cc b/src/format.cc index c546926e..bde39882 100644 --- a/src/format.cc +++ b/src/format.cc @@ -37,8 +37,8 @@ namespace ledger { -format_t::elision_style_t format_t::default_style = TRUNCATE_TRAILING; -bool format_t::default_style_changed = false; +format_t::elision_style_t format_t::default_style = TRUNCATE_TRAILING; +bool format_t::default_style_changed = false; void format_t::element_t::dump(std::ostream& out) const { @@ -88,14 +88,14 @@ namespace { // Don't gobble up any whitespace const char * base = p; while (p >= base && std::isspace(*p)) - p--; + p--; } return expr; } } format_t::element_t * format_t::parse_elements(const string& fmt, - const optional<format_t&>& tmpl) + const optional<format_t&>& tmpl) { std::auto_ptr<element_t> result; @@ -147,8 +147,8 @@ format_t::element_t * format_t::parse_elements(const string& fmt, while (*p == '-') { switch (*p) { case '-': - current->add_flags(ELEMENT_ALIGN_LEFT); - break; + current->add_flags(ELEMENT_ALIGN_LEFT); + break; } ++p; } @@ -164,12 +164,12 @@ format_t::element_t * format_t::parse_elements(const string& fmt, ++p; num = 0; while (*p && std::isdigit(*p)) { - num *= 10; - num += *p++ - '0'; + num *= 10; + num += *p++ - '0'; } current->max_width = num; if (current->min_width == 0) - current->min_width = current->max_width; + current->min_width = current->max_width; } switch (*p) { @@ -180,25 +180,25 @@ format_t::element_t * format_t::parse_elements(const string& fmt, case '$': { if (! tmpl) - throw_(format_error, _("Prior field reference, but no template")); + throw_(format_error, _("Prior field reference, but no template")); p++; if (*p == '0' || (! std::isdigit(*p) && - *p != 'A' && *p != 'B' && *p != 'C' && - *p != 'D' && *p != 'E' && *p != 'F')) - throw_(format_error, _("%$ field reference must be a digit from 1-9")); + *p != 'A' && *p != 'B' && *p != 'C' && + *p != 'D' && *p != 'E' && *p != 'F')) + throw_(format_error, _("%$ field reference must be a digit from 1-9")); unsigned int index = std::isdigit(*p) ? *p - '0' : (*p - 'A' + 10); element_t * tmpl_elem = tmpl->elements.get(); for (unsigned int i = 1; i < index && tmpl_elem; i++) { - tmpl_elem = tmpl_elem->next.get(); - while (tmpl_elem && tmpl_elem->type != element_t::EXPR) - tmpl_elem = tmpl_elem->next.get(); + tmpl_elem = tmpl_elem->next.get(); + while (tmpl_elem && tmpl_elem->type != element_t::EXPR) + tmpl_elem = tmpl_elem->next.get(); } if (! tmpl_elem) - throw_(format_error, _("%$ reference to a non-existent prior field")); + throw_(format_error, _("%$ reference to a non-existent prior field")); *current = *tmpl_elem; break; @@ -214,87 +214,87 @@ format_t::element_t * format_t::parse_elements(const string& fmt, // Wrap the subexpression in calls to justify and scrub if (format_amount) { - if (! *p || *(p + 1) != '}') - throw_(format_error, _("Expected closing brace")); - else - p++; + if (! *p || *(p + 1) != '}') + throw_(format_error, _("Expected closing brace")); + else + p++; - expr_t::ptr_op_t op = boost::get<expr_t>(current->data).get_op(); + expr_t::ptr_op_t op = boost::get<expr_t>(current->data).get_op(); - expr_t::ptr_op_t amount_op; - expr_t::ptr_op_t colorize_op; - if (op->kind == expr_t::op_t::O_CONS) { - amount_op = op->left(); - colorize_op = op->right(); - } else { - amount_op = op; - } + expr_t::ptr_op_t amount_op; + expr_t::ptr_op_t colorize_op; + if (op->kind == expr_t::op_t::O_CONS) { + amount_op = op->left(); + colorize_op = op->right(); + } else { + amount_op = op; + } - expr_t::ptr_op_t scrub_node(new expr_t::op_t(expr_t::op_t::IDENT)); - scrub_node->set_ident("scrub"); + expr_t::ptr_op_t scrub_node(new expr_t::op_t(expr_t::op_t::IDENT)); + scrub_node->set_ident("scrub"); - expr_t::ptr_op_t call1_node(new expr_t::op_t(expr_t::op_t::O_CALL)); - call1_node->set_left(scrub_node); - call1_node->set_right(amount_op); + expr_t::ptr_op_t call1_node(new expr_t::op_t(expr_t::op_t::O_CALL)); + call1_node->set_left(scrub_node); + call1_node->set_right(amount_op); - expr_t::ptr_op_t arg1_node(new expr_t::op_t(expr_t::op_t::VALUE)); - expr_t::ptr_op_t arg2_node(new expr_t::op_t(expr_t::op_t::VALUE)); - expr_t::ptr_op_t arg3_node(new expr_t::op_t(expr_t::op_t::VALUE)); + expr_t::ptr_op_t arg1_node(new expr_t::op_t(expr_t::op_t::VALUE)); + expr_t::ptr_op_t arg2_node(new expr_t::op_t(expr_t::op_t::VALUE)); + expr_t::ptr_op_t arg3_node(new expr_t::op_t(expr_t::op_t::VALUE)); - arg1_node->set_value(current->min_width > 0 ? - long(current->min_width) : -1); - arg2_node->set_value(current->max_width > 0 ? - long(current->max_width) : -1); - arg3_node->set_value(! current->has_flags(ELEMENT_ALIGN_LEFT)); + arg1_node->set_value(current->min_width > 0 ? + long(current->min_width) : -1); + arg2_node->set_value(current->max_width > 0 ? + long(current->max_width) : -1); + arg3_node->set_value(! current->has_flags(ELEMENT_ALIGN_LEFT)); - current->min_width = 0; - current->max_width = 0; + current->min_width = 0; + current->max_width = 0; - expr_t::ptr_op_t args1_node(new expr_t::op_t(expr_t::op_t::O_CONS)); - args1_node->set_left(arg2_node); - args1_node->set_right(arg3_node); + expr_t::ptr_op_t args1_node(new expr_t::op_t(expr_t::op_t::O_CONS)); + args1_node->set_left(arg2_node); + args1_node->set_right(arg3_node); - expr_t::ptr_op_t args2_node(new expr_t::op_t(expr_t::op_t::O_CONS)); - args2_node->set_left(arg1_node); - args2_node->set_right(args1_node); + expr_t::ptr_op_t args2_node(new expr_t::op_t(expr_t::op_t::O_CONS)); + args2_node->set_left(arg1_node); + args2_node->set_right(args1_node); - expr_t::ptr_op_t args3_node(new expr_t::op_t(expr_t::op_t::O_CONS)); - args3_node->set_left(call1_node); - args3_node->set_right(args2_node); + expr_t::ptr_op_t args3_node(new expr_t::op_t(expr_t::op_t::O_CONS)); + args3_node->set_left(call1_node); + args3_node->set_right(args2_node); - expr_t::ptr_op_t seq1_node(new expr_t::op_t(expr_t::op_t::O_SEQ)); - seq1_node->set_left(args3_node); + expr_t::ptr_op_t seq1_node(new expr_t::op_t(expr_t::op_t::O_SEQ)); + seq1_node->set_left(args3_node); - expr_t::ptr_op_t justify_node(new expr_t::op_t(expr_t::op_t::IDENT)); - justify_node->set_ident("justify"); + expr_t::ptr_op_t justify_node(new expr_t::op_t(expr_t::op_t::IDENT)); + justify_node->set_ident("justify"); - expr_t::ptr_op_t call2_node(new expr_t::op_t(expr_t::op_t::O_CALL)); - call2_node->set_left(justify_node); - call2_node->set_right(seq1_node); + expr_t::ptr_op_t call2_node(new expr_t::op_t(expr_t::op_t::O_CALL)); + call2_node->set_left(justify_node); + call2_node->set_right(seq1_node); - string prev_expr = boost::get<expr_t>(current->data).text(); + string prev_expr = boost::get<expr_t>(current->data).text(); - if (colorize_op) { - expr_t::ptr_op_t ansify_if_node(new expr_t::op_t(expr_t::op_t::IDENT)); - ansify_if_node->set_ident("ansify_if"); + if (colorize_op) { + expr_t::ptr_op_t ansify_if_node(new expr_t::op_t(expr_t::op_t::IDENT)); + ansify_if_node->set_ident("ansify_if"); - expr_t::ptr_op_t args4_node(new expr_t::op_t(expr_t::op_t::O_CONS)); - args4_node->set_left(call2_node); - args4_node->set_right(colorize_op); + expr_t::ptr_op_t args4_node(new expr_t::op_t(expr_t::op_t::O_CONS)); + args4_node->set_left(call2_node); + args4_node->set_right(colorize_op); - expr_t::ptr_op_t seq2_node(new expr_t::op_t(expr_t::op_t::O_SEQ)); - seq2_node->set_left(args4_node); + expr_t::ptr_op_t seq2_node(new expr_t::op_t(expr_t::op_t::O_SEQ)); + seq2_node->set_left(args4_node); - expr_t::ptr_op_t call3_node(new expr_t::op_t(expr_t::op_t::O_CALL)); - call3_node->set_left(ansify_if_node); - call3_node->set_right(seq2_node); + expr_t::ptr_op_t call3_node(new expr_t::op_t(expr_t::op_t::O_CALL)); + call3_node->set_left(ansify_if_node); + call3_node->set_right(seq2_node); - current->data = expr_t(call3_node); - } else { - current->data = expr_t(call2_node); - } + current->data = expr_t(call3_node); + } else { + current->data = expr_t(call2_node); + } - boost::get<expr_t>(current->data).set_text(prev_expr); + boost::get<expr_t>(current->data).set_text(prev_expr); } break; } @@ -335,7 +335,7 @@ string format_t::real_calc(scope_t& scope) switch (elem->type) { case element_t::STRING: if (elem->min_width > 0) - out.width(elem->min_width); + out.width(elem->min_width); out << boost::get<string>(elem->data); break; @@ -343,28 +343,28 @@ string format_t::real_calc(scope_t& scope) expr_t& expr(boost::get<expr_t>(elem->data)); try { - expr.compile(scope); - - value_t value; - if (expr.is_function()) { - call_scope_t args(scope); - args.push_back(long(elem->max_width)); - value = expr.get_function()(args); - } else { - value = expr.calc(scope); - } - DEBUG("format.expr", "value = (" << value << ")"); - - if (elem->min_width > 0) - value.print(out, static_cast<int>(elem->min_width), -1, - ! elem->has_flags(ELEMENT_ALIGN_LEFT)); - else - out << value.to_string(); + expr.compile(scope); + + value_t value; + if (expr.is_function()) { + call_scope_t args(scope); + args.push_back(long(elem->max_width)); + value = expr.get_function()(args); + } else { + value = expr.calc(scope); + } + DEBUG("format.expr", "value = (" << value << ")"); + + if (elem->min_width > 0) + value.print(out, static_cast<int>(elem->min_width), -1, + ! elem->has_flags(ELEMENT_ALIGN_LEFT)); + else + out << value.to_string(); } catch (const calc_error&) { - add_error_context(_("While calculating format expression:")); - add_error_context(expr.context_to_str()); - throw; + add_error_context(_("While calculating format expression:")); + add_error_context(expr.context_to_str()); + throw; } break; } @@ -376,15 +376,15 @@ string format_t::real_calc(scope_t& scope) if (elem->max_width > 0 || elem->min_width > 0) { unistring temp(out.str()); - string result; + string result; if (elem->max_width > 0 && elem->max_width < temp.length()) { - result = truncate(temp, elem->max_width); + result = truncate(temp, elem->max_width); } else { - result = temp.extract(); - if (elem->min_width > temp.length()) - for (std::size_t i = 0; i < elem->min_width - temp.length(); i++) - result += " "; + result = temp.extract(); + if (elem->min_width > temp.length()) + for (std::size_t i = 0; i < elem->min_width - temp.length(); i++) + result += " "; } out_str << result; } else { @@ -396,8 +396,8 @@ string format_t::real_calc(scope_t& scope) } string format_t::truncate(const unistring& ustr, - const std::size_t width, - const std::size_t account_abbrev_length) + const std::size_t width, + const std::size_t account_abbrev_length) { assert(width < 4095); @@ -420,9 +420,9 @@ string format_t::truncate(const unistring& ustr, case TRUNCATE_MIDDLE: // This method truncates in the middle. buf << ustr.extract(0, (width - 2) / 2) - << ".." - << ustr.extract(len - ((width - 2) / 2 + (width - 2) % 2), - (width - 2) / 2 + (width - 2) % 2); + << ".." + << ustr.extract(len - ((width - 2) / 2 + (width - 2) % 2), + (width - 2) / 2 + (width - 2) % 2); break; case ABBREVIATE: @@ -431,46 +431,46 @@ string format_t::truncate(const unistring& ustr, string::size_type beg = 0; string strcopy(ustr.extract()); for (string::size_type pos = strcopy.find(':'); - pos != string::npos; - beg = pos + 1, pos = strcopy.find(':', beg)) - parts.push_back(string(strcopy, beg, pos - beg)); + pos != string::npos; + beg = pos + 1, pos = strcopy.find(':', beg)) + parts.push_back(string(strcopy, beg, pos - beg)); parts.push_back(string(strcopy, beg)); std::ostringstream result; std::size_t newlen = len; for (std::list<string>::iterator i = parts.begin(); - i != parts.end(); - i++) { - // Don't contract the last element - std::list<string>::iterator x = i; - if (++x == parts.end()) { - result << *i; - break; - } - - if (newlen > width) { - unistring temp(*i); - if (temp.length() > account_abbrev_length) { - result << temp.extract(0, account_abbrev_length) << ":"; - newlen -= temp.length() - account_abbrev_length; - } else { - result << temp.extract() << ":"; - newlen -= temp.length(); - } - } else { - result << *i << ":"; - } + i != parts.end(); + i++) { + // Don't contract the last element + std::list<string>::iterator x = i; + if (++x == parts.end()) { + result << *i; + break; + } + + if (newlen > width) { + unistring temp(*i); + if (temp.length() > account_abbrev_length) { + result << temp.extract(0, account_abbrev_length) << ":"; + newlen -= temp.length() - account_abbrev_length; + } else { + result << temp.extract() << ":"; + newlen -= temp.length(); + } + } else { + result << *i << ":"; + } } if (newlen > width) { - // Even abbreviated its too big to show the last account, so - // abbreviate all but the last and truncate at the beginning. - unistring temp(result.str()); - assert(temp.length() > width - 2); - buf << ".." << temp.extract(temp.length() - (width - 2), width - 2); + // Even abbreviated its too big to show the last account, so + // abbreviate all but the last and truncate at the beginning. + unistring temp(result.str()); + assert(temp.length() > width - 2); + buf << ".." << temp.extract(temp.length() - (width - 2), width - 2); } else { - buf << result.str(); + buf << result.str(); } break; } diff --git a/src/format.h b/src/format.h index 72d44ee5..a0b95567 100644 --- a/src/format.h +++ b/src/format.h @@ -61,10 +61,10 @@ class format_t : public expr_base_t<string> enum kind_t { STRING, EXPR }; - kind_t type; - std::size_t min_width; - std::size_t max_width; - variant<string, expr_t> data; + kind_t type; + std::size_t min_width; + std::size_t max_width; + variant<string, expr_t> data; scoped_ptr<struct element_t> next; element_t() throw() @@ -80,11 +80,11 @@ class format_t : public expr_base_t<string> element_t& operator=(const element_t& elem) { if (this != &elem) { - supports_flags<>::operator=(elem); - type = elem.type; - min_width = elem.min_width; - max_width = elem.max_width; - data = elem.data; + supports_flags<>::operator=(elem); + type = elem.type; + min_width = elem.min_width; + max_width = elem.max_width; + data = elem.data; } return *this; } @@ -95,12 +95,12 @@ class format_t : public expr_base_t<string> out << "\033[31m"; if (elem->has_flags(ELEMENT_ALIGN_LEFT)) - out << std::left; + out << std::left; else - out << std::right; + out << std::right; if (elem->min_width > 0) - out.width(elem->min_width); + out.width(elem->min_width); } void dump(std::ostream& out) const; @@ -120,7 +120,7 @@ public: private: static element_t * parse_elements(const string& fmt, - const optional<format_t&>& tmpl); + const optional<format_t&>& tmpl); public: format_t() : base_type() { @@ -137,7 +137,7 @@ public: } void parse_format(const string& _format, - const optional<format_t&>& tmpl = none) { + const optional<format_t&>& tmpl = none) { elements.reset(parse_elements(_format, tmpl)); set_text(_format); } @@ -146,14 +146,14 @@ public: virtual void dump(std::ostream& out) const { for (const element_t * elem = elements.get(); - elem; - elem = elem->next.get()) + elem; + elem = elem->next.get()) elem->dump(out); } static string truncate(const unistring& str, - const std::size_t width, - const std::size_t account_abbrev_length = 0); + const std::size_t width, + const std::size_t account_abbrev_length = 0); }; } // namespace ledger diff --git a/src/generate.cc b/src/generate.cc index 8ea1ab45..fbfca342 100644 --- a/src/generate.cc +++ b/src/generate.cc @@ -60,8 +60,8 @@ generate_posts_iterator::generate_posts_iterator two_six_range(2, 6), two_six_gen(rnd_gen, two_six_range), strlen_range(1, 40), strlen_gen(rnd_gen, strlen_range), - neg_number_range(-1000000, -1), neg_number_gen(rnd_gen, neg_number_range), - pos_number_range(1, 1000000), pos_number_gen(rnd_gen, pos_number_range) + neg_number_range(-10000, -1), neg_number_gen(rnd_gen, neg_number_range), + pos_number_range(1, 10000), pos_number_gen(rnd_gen, pos_number_range) { TRACE_CTOR(generate_posts_iterator, "bool"); @@ -76,10 +76,10 @@ generate_posts_iterator::generate_posts_iterator } void generate_posts_iterator::generate_string(std::ostream& out, int len, - bool only_alpha) + bool only_alpha) { DEBUG("generate.post.string", - "Generating string of length " << len << ", only alpha " << only_alpha); + "Generating string of length " << len << ", only alpha " << only_alpha); int last = -1; bool first = true; @@ -87,38 +87,38 @@ void generate_posts_iterator::generate_string(std::ostream& out, int len, int next = only_alpha ? 3 : three_gen(); bool output = true; switch (next) { - case 1: // colon + case 1: // colon if (! first && last == 3 && strlen_gen() % 10 == 0 && i + 1 != len) - out << ':'; + out << ':'; else { - i--; - output = false; + i--; + output = false; } break; - case 2: // space + case 2: // space if (! first && last == 3 && strlen_gen() % 20 == 0 && i + 1 != len) - out << ' '; + out << ' '; else { - i--; - output = false; + i--; + output = false; } break; - case 3: // character + case 3: // character switch (three_gen()) { - case 1: // uppercase - out << char(upchar_gen()); - break; - case 2: // lowercase - out << char(downchar_gen()); - break; - case 3: // number - if (! only_alpha && ! first) - out << char(numchar_gen()); - else { - i--; - output = false; - } - break; + case 1: // uppercase + out << char(upchar_gen()); + break; + case 2: // lowercase + out << char(downchar_gen()); + break; + case 3: // number + if (! only_alpha && ! first) + out << char(numchar_gen()); + else { + i--; + output = false; + } + break; } break; } @@ -130,7 +130,7 @@ void generate_posts_iterator::generate_string(std::ostream& out, int len, } bool generate_posts_iterator::generate_account(std::ostream& out, - bool no_virtual) + bool no_virtual) { bool must_balance = true; bool is_virtual = false; @@ -164,7 +164,7 @@ bool generate_posts_iterator::generate_account(std::ostream& out, } void generate_posts_iterator::generate_commodity(std::ostream& out, - const string& exclude) + const string& exclude) { string comm; do { @@ -173,21 +173,21 @@ void generate_posts_iterator::generate_commodity(std::ostream& out, comm = buf.str(); } while (comm == exclude || comm == "h" || comm == "m" || comm == "s" || - comm == "and" || comm == "any" || comm == "all" || comm == "div" || - comm == "false" || comm == "or" || comm == "not" || - comm == "true" || comm == "if" || comm == "else"); + comm == "and" || comm == "any" || comm == "all" || comm == "div" || + comm == "false" || comm == "or" || comm == "not" || + comm == "true" || comm == "if" || comm == "else"); out << comm; } string generate_posts_iterator::generate_amount(std::ostream& out, - value_t not_this_amount, - bool no_negative, - const string& exclude) + value_t not_this_amount, + bool no_negative, + const string& exclude) { std::ostringstream buf; - if (truth_gen()) { // commodity goes in front + if (truth_gen()) { // commodity goes in front generate_commodity(buf, exclude); if (truth_gen()) buf << ' '; @@ -262,7 +262,7 @@ void generate_posts_iterator::generate_cost(std::ostream& out, value_t amount) buf << " @@ "; if (! generate_amount(buf, amount, true, - amount.as_amount().commodity().symbol()).empty()) + amount.as_amount().commodity().symbol()).empty()) out << buf.str(); } @@ -362,20 +362,20 @@ post_t * generate_posts_iterator::operator()() std::istringstream in(buf.str()); try { if (session.journal->parse(in, session) != 0) { - VERIFY(session.journal->xacts.back()->valid()); - posts.reset(*session.journal->xacts.back()); - post = posts(); + VERIFY(session.journal->xacts.back()->valid()); + posts.reset(*session.journal->xacts.back()); + post = posts(); } } catch (std::exception& err) { add_error_context(_("While parsing generated transaction (seed %1):") - << seed); + << seed); add_error_context(buf.str()); throw; } catch (int status) { add_error_context(_("While parsing generated transaction (seed %1):") - << seed); + << seed); add_error_context(buf.str()); throw; } diff --git a/src/generate.h b/src/generate.h index f0f58064..25ad41ea 100644 --- a/src/generate.h +++ b/src/generate.h @@ -53,7 +53,7 @@ class generate_posts_iterator : public posts_iterator session_t& session; unsigned int seed; std::size_t quantity; - bool allow_invalid; + bool allow_invalid; date_t next_date; date_t next_eff_date; @@ -97,9 +97,9 @@ class generate_posts_iterator : public posts_iterator public: generate_posts_iterator(session_t& _session, - unsigned int _seed = 0, - std::size_t _quantity = 100, - bool _allow_invalid = false); + unsigned int _seed = 0, + std::size_t _quantity = 100, + bool _allow_invalid = false); virtual ~generate_posts_iterator() throw() { TRACE_DTOR(generate_posts_iterator); @@ -108,21 +108,21 @@ public: virtual post_t * operator()(); protected: - void generate_string(std::ostream& out, int len, bool only_alpha = false); - bool generate_account(std::ostream& out, bool no_virtual = false); - void generate_commodity(std::ostream& out, const string& exclude = ""); + void generate_string(std::ostream& out, int len, bool only_alpha = false); + bool generate_account(std::ostream& out, bool no_virtual = false); + void generate_commodity(std::ostream& out, const string& exclude = ""); string generate_amount(std::ostream& out, - value_t not_this_amount = NULL_VALUE, - bool no_negative = false, - const string& exclude = ""); - bool generate_post(std::ostream& out, bool no_amount = false); - void generate_cost(std::ostream& out, value_t amount); - void generate_date(std::ostream& out); - void generate_state(std::ostream& out); - void generate_code(std::ostream& out); - void generate_payee(std::ostream& out); - void generate_note(std::ostream& out); - void generate_xact(std::ostream& out); + value_t not_this_amount = NULL_VALUE, + bool no_negative = false, + const string& exclude = ""); + bool generate_post(std::ostream& out, bool no_amount = false); + void generate_cost(std::ostream& out, value_t amount); + void generate_date(std::ostream& out); + void generate_state(std::ostream& out); + void generate_code(std::ostream& out); + void generate_payee(std::ostream& out); + void generate_note(std::ostream& out); + void generate_xact(std::ostream& out); }; } // namespace ledger diff --git a/src/global.cc b/src/global.cc index 35651ddb..eb138f25 100644 --- a/src/global.cc +++ b/src/global.cc @@ -113,10 +113,10 @@ void global_scope_t::read_init() ifstream init(init_file); if (session().journal->read(init_file, NULL, &report()) > 0 || - session().journal->auto_xacts.size() > 0 || - session().journal->period_xacts.size() > 0) { - throw_(parse_error, _("Transactions found in initialization file '%1'") - << init_file); + session().journal->auto_xacts.size() > 0 || + session().journal->period_xacts.size() > 0) { + throw_(parse_error, _("Transactions found in initialization file '%1'") + << init_file); } TRACE_FINISH(init, 1); @@ -137,7 +137,7 @@ char * global_scope_t::prompt_string() void global_scope_t::report_error(const std::exception& err) { - std::cout.flush(); // first display anything that was pending + std::cout.flush(); // first display anything that was pending if (caught_signal == NONE_CAUGHT) { // Display any pending error context information @@ -163,7 +163,7 @@ void global_scope_t::execute_command(strings_list args, bool at_repl) } strings_list::iterator arg = args.begin(); - string verb = *arg++; + string verb = *arg++; // Look for a precommand first, which is defined as any defined function // whose name starts with "ledger_precmd_". The difference between a @@ -180,8 +180,8 @@ void global_scope_t::execute_command(strings_list args, bool at_repl) // then invoke the command. expr_t::func_t command; - bool is_precommand = false; - bind_scope_t bound_scope(*this, report()); + bool is_precommand = false; + bind_scope_t bound_scope(*this, report()); if (bool(command = look_for_precommand(bound_scope, verb))) is_precommand = true; @@ -206,11 +206,11 @@ void global_scope_t::execute_command(strings_list args, bool at_repl) report().output_stream .initialize(report().HANDLED(output_) ? - optional<path>(path(report().HANDLER(output_).str())) : - optional<path>(), - report().HANDLED(pager_) ? - optional<path>(path(report().HANDLER(pager_).str())) : - optional<path>()); + optional<path>(path(report().HANDLER(output_).str())) : + optional<path>(), + report().HANDLED(pager_) ? + optional<path>(path(report().HANDLER(pager_).str())) : + optional<path>()); // Now that the output stream is initialized, report the options that will // participate in this report, if the user specified --options @@ -316,7 +316,7 @@ option_t<global_scope_t> * global_scope_t::lookup_option(const char * p) } expr_t::ptr_op_t global_scope_t::lookup(const symbol_t::kind_t kind, - const string& name) + const string& name) { switch (kind) { case symbol_t::FUNCTION: @@ -334,9 +334,9 @@ expr_t::ptr_op_t global_scope_t::lookup(const symbol_t::kind_t kind, switch (*p) { case 'p': if (is_eq(p, "push")) - return MAKE_FUNCTOR(global_scope_t::push_command); + return MAKE_FUNCTOR(global_scope_t::push_command); else if (is_eq(p, "pop")) - return MAKE_FUNCTOR(global_scope_t::pop_command); + return MAKE_FUNCTOR(global_scope_t::pop_command); break; } } @@ -400,8 +400,8 @@ void global_scope_t::normalize_session_options() #endif // defined(LOGGING_ON) } -expr_t::func_t global_scope_t::look_for_precommand(scope_t& scope, - const string& verb) +expr_t::func_t global_scope_t::look_for_precommand(scope_t& scope, + const string& verb) { if (expr_t::ptr_op_t def = scope.lookup(symbol_t::PRECOMMAND, verb)) return def->as_function(); @@ -410,7 +410,7 @@ expr_t::func_t global_scope_t::look_for_precommand(scope_t& scope, } expr_t::func_t global_scope_t::look_for_command(scope_t& scope, - const string& verb) + const string& verb) { if (expr_t::ptr_op_t def = scope.lookup(symbol_t::COMMAND, verb)) return def->as_function(); @@ -424,7 +424,7 @@ void global_scope_t::visit_man_page() const if (pid < 0) { throw std::logic_error(_("Failed to fork child process")); } - else if (pid == 0) { // child + else if (pid == 0) { // child execlp("man", "man", "1", "ledger", NULL); // We should never, ever reach here @@ -434,7 +434,7 @@ void global_scope_t::visit_man_page() const int status = -1; wait(&status); - exit(0); // parent + exit(0); // parent } void handle_debug_options(int argc, char * argv[]) @@ -442,37 +442,37 @@ void handle_debug_options(int argc, char * argv[]) for (int i = 1; i < argc; i++) { if (argv[i][0] == '-') { if (std::strcmp(argv[i], "--args-only") == 0) { - args_only = true; + args_only = true; } else if (std::strcmp(argv[i], "--verify") == 0) { #if defined(VERIFY_ON) - verify_enabled = true; // global in utils.h + verify_enabled = true; // global in utils.h #endif } else if (std::strcmp(argv[i], "--verbose") == 0 || - std::strcmp(argv[i], "-v") == 0) { + std::strcmp(argv[i], "-v") == 0) { #if defined(LOGGING_ON) - _log_level = LOG_INFO; // global in utils.h + _log_level = LOG_INFO; // global in utils.h #endif } else if (i + 1 < argc && std::strcmp(argv[i], "--debug") == 0) { #if defined(DEBUG_ON) - _log_level = LOG_DEBUG; // global in utils.h - _log_category = argv[i + 1]; // global in utils.h - i++; + _log_level = LOG_DEBUG; // global in utils.h + _log_category = argv[i + 1]; // global in utils.h + i++; #endif } else if (i + 1 < argc && std::strcmp(argv[i], "--trace") == 0) { #if defined(TRACING_ON) - _log_level = LOG_TRACE; // global in utils.h - try { - // global in utils.h - _trace_level = boost::lexical_cast<uint8_t>(argv[i + 1]); - } - catch (const boost::bad_lexical_cast& e) { - throw std::logic_error(_("Argument to --trace must be an integer")); - } - i++; + _log_level = LOG_TRACE; // global in utils.h + try { + // global in utils.h + _trace_level = boost::lexical_cast<uint8_t>(argv[i + 1]); + } + catch (const boost::bad_lexical_cast& e) { + throw std::logic_error(_("Argument to --trace must be an integer")); + } + i++; #endif } } diff --git a/src/global.h b/src/global.h index 05e3bdb7..87f2495a 100644 --- a/src/global.h +++ b/src/global.h @@ -50,16 +50,16 @@ class report_t; class global_scope_t : public noncopyable, public scope_t { shared_ptr<session_t> session_ptr; - ptr_list<report_t> report_stack; + ptr_list<report_t> report_stack; public: global_scope_t(char ** envp); ~global_scope_t(); - void read_init(); - void read_environment_settings(char * envp[]); - strings_list read_command_arguments(scope_t& scope, strings_list args); - void normalize_session_options(); + void read_init(); + void read_environment_settings(char * envp[]); + strings_list read_command_arguments(scope_t& scope, strings_list args); + void normalize_session_options(); expr_t::func_t look_for_precommand(scope_t& scope, const string& verb); expr_t::func_t look_for_command(scope_t& scope, const string& verb); @@ -98,7 +98,7 @@ public: // open output stream at this point. We want it to get popped off as // soon as this command terminate so that the stream is closed cleanly. report_stack.insert(++report_stack.begin(), - new report_t(report_stack.front())); + new report_t(report_stack.front())); return true; } value_t pop_command(call_scope_t&) { @@ -121,7 +121,7 @@ See LICENSE file included with the distribution for details and disclaimer."); option_t<global_scope_t> * lookup_option(const char * p); virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name); + const string& name); OPTION(global_scope_t, args_only); OPTION(global_scope_t, debug_); @@ -152,7 +152,7 @@ See LICENSE file included with the distribution for details and disclaimer."); OPTION_(global_scope_t, version, DO() { // -v parent->show_version_info(std::cout); - throw int(0); // exit immediately + throw int(0); // exit immediately }); }; diff --git a/src/interactive.cc b/src/interactive.cc index 9aeb5307..54c7fd6c 100644 --- a/src/interactive.cc +++ b/src/interactive.cc @@ -39,16 +39,16 @@ void interactive_t::verify_arguments() const { value_t::sequence_t::const_iterator i; - const char * p = spec.c_str(); - const char * label = _("unknown"); - bool wrong_arg = false; - bool dont_skip = false; - bool optional = *p == '&'; - bool exit_loop = *p == '*'; - std::size_t offset = 1; - bool is_seq = args.value().is_sequence(); + const char * p = spec.c_str(); + const char * label = _("unknown"); + bool wrong_arg = false; + bool dont_skip = false; + bool optional = *p == '&'; + bool exit_loop = *p == '*'; + std::size_t offset = 1; + bool is_seq = args.value().is_sequence(); const value_t * next_arg = NULL; - string vlabel; + string vlabel; if (is_seq) { i = args.begin(); @@ -61,45 +61,45 @@ void interactive_t::verify_arguments() const for (; ! wrong_arg && ! exit_loop && *p && next_arg; p++) { DEBUG("interactive.verify", - "Want " << *p << " got: " << next_arg->label()); + "Want " << *p << " got: " << next_arg->label()); wrong_arg = false; switch (*p) { case 'a': label = _("an amount"); wrong_arg = (! next_arg->is_long() && - ! next_arg->is_amount() && - ! next_arg->is_balance()); + ! next_arg->is_amount() && + ! next_arg->is_balance()); break; case 'b': label = _("a boolean"); - wrong_arg = false; // booleans are converted + wrong_arg = false; // booleans are converted break; case 'd': label = _("a date"); wrong_arg = (! next_arg->is_date() && - ! next_arg->is_datetime()); + ! next_arg->is_datetime()); break; case 't': label = _("a date/time"); wrong_arg = (! next_arg->is_date() && - ! next_arg->is_datetime()); + ! next_arg->is_datetime()); break; case 'i': case 'l': label = _("an integer"); if (next_arg->is_long() || - (next_arg->is_amount() && - ! next_arg->as_amount().has_commodity())) { + (next_arg->is_amount() && + ! next_arg->as_amount().has_commodity())) { wrong_arg = false; } else if (next_arg->is_string()) { wrong_arg = false; for (const char * q = next_arg->as_string().c_str(); *q; q++) { - if (! std::isdigit(*q) && *q != '-') { - wrong_arg = true; - break; - } + if (! std::isdigit(*q) && *q != '-') { + wrong_arg = true; + break; + } } } else { @@ -143,19 +143,21 @@ void interactive_t::verify_arguments() const if (wrong_arg && optional && next_arg->is_null()) wrong_arg = false; - if (wrong_arg) + if (wrong_arg) { vlabel = next_arg->label(); + break; + } if (! dont_skip) { if (is_seq) { - if (++i != args.end()) { - next_arg = &(*i); - offset++; - } else { - next_arg = NULL; - } + if (++i != args.end()) { + next_arg = &(*i); + offset++; + } else { + next_arg = NULL; + } } else { - next_arg = NULL; + next_arg = NULL; } } dont_skip = false; @@ -168,8 +170,8 @@ void interactive_t::verify_arguments() const if (wrong_arg) { throw_(std::logic_error, - _("Expected %1 for argument %2, but received %3") - << label << offset << vlabel); + _("Expected %1 for argument %2, but received %3") + << label << offset << vlabel); } else if (*p && ! optional && ! next_arg) { throw_(std::logic_error, _("Too few arguments to function")); diff --git a/src/item.cc b/src/item.cc index 6a948ae4..f59c9e29 100644 --- a/src/item.cc +++ b/src/item.cc @@ -58,22 +58,22 @@ bool item_t::has_tag(const string& tag) const } bool item_t::has_tag(const mask_t& tag_mask, - const optional<mask_t>& value_mask) const + const optional<mask_t>& value_mask) const { if (metadata) { foreach (const string_map::value_type& data, *metadata) { if (tag_mask.match(data.first)) { - if (! value_mask) - return true; - else if (data.second.first) - return value_mask->match(*data.second.first); + if (! value_mask) + return true; + else if (data.second.first) + return value_mask->match(data.second.first->to_string()); } } } return false; } -optional<string> item_t::get_tag(const string& tag) const +optional<value_t> item_t::get_tag(const string& tag) const { DEBUG("item.meta", "Getting item tag: " << tag); if (metadata) { @@ -87,24 +87,26 @@ optional<string> item_t::get_tag(const string& tag) const return none; } -optional<string> item_t::get_tag(const mask_t& tag_mask, - const optional<mask_t>& value_mask) const +optional<value_t> item_t::get_tag(const mask_t& tag_mask, + const optional<mask_t>& value_mask) const { if (metadata) { foreach (const string_map::value_type& data, *metadata) { if (tag_mask.match(data.first) && - (! value_mask || - (data.second.first && value_mask->match(*data.second.first)))) - return data.second.first; + (! value_mask || + (data.second.first && + value_mask->match(data.second.first->to_string())))) { + return data.second.first; + } } } return none; } item_t::string_map::iterator -item_t::set_tag(const string& tag, - const optional<string>& value, - const bool overwrite_existing) +item_t::set_tag(const string& tag, + const optional<value_t>& value, + const bool overwrite_existing) { assert(! tag.empty()); @@ -112,10 +114,12 @@ item_t::set_tag(const string& tag, metadata = string_map(); DEBUG("item.meta", "Setting tag '" << tag << "' to value '" - << (value ? *value : string("<none>")) << "'"); + << (value ? *value : string_value("<none>")) << "'"); - optional<string> data = value; - if (data && data->empty()) + optional<value_t> data = value; + if (data && + (data->is_null() || + (data->is_string() && data->as_string().empty()))) data = none; string_map::iterator i = metadata->find(tag); @@ -131,23 +135,25 @@ item_t::set_tag(const string& tag, } } -void item_t::parse_tags(const char * p, bool overwrite_existing, - optional<date_t::year_type> current_year) +void item_t::parse_tags(const char * p, + scope_t& scope, + bool overwrite_existing, + optional<date_t::year_type> current_year) { if (const char * b = std::strchr(p, '[')) { if (*(b + 1) != '\0' && - (std::isdigit(*(b + 1)) || *(b + 1) == '=')) { + (std::isdigit(*(b + 1)) || *(b + 1) == '=')) { if (const char * e = std::strchr(p, ']')) { - char buf[256]; - std::strncpy(buf, b + 1, e - b - 1); - buf[e - b - 1] = '\0'; - - if (char * p = std::strchr(buf, '=')) { - *p++ = '\0'; - _date_eff = parse_date(p, current_year); - } - if (buf[0]) - _date = parse_date(buf, current_year); + char buf[256]; + std::strncpy(buf, b + 1, e - b - 1); + buf[e - b - 1] = '\0'; + + if (char * p = std::strchr(buf, '=')) { + *p++ = '\0'; + _date_eff = parse_date(p, current_year); + } + if (buf[0]) + _date = parse_date(buf, current_year); } } } @@ -160,32 +166,47 @@ void item_t::parse_tags(const char * p, bool overwrite_existing, std::strcpy(buf.get(), p); string tag; + bool by_value = false; for (char * q = std::strtok(buf.get(), " \t"); q; q = std::strtok(NULL, " \t")) { const string::size_type len = std::strlen(q); + if (len < 2) continue; if (! tag.empty()) { - string_map::iterator i = set_tag(tag, string(p + (q - buf.get())), - overwrite_existing); + string_map::iterator i; + string field(p + (q - buf.get())); + if (by_value) { + bind_scope_t bound_scope(scope, *this); + i = set_tag(tag, expr_t(field).calc(bound_scope), overwrite_existing); + } else { + i = set_tag(tag, string_value(field), overwrite_existing); + } (*i).second.second = true; break; } else if (q[0] == ':' && q[len - 1] == ':') { // a series of tags for (char * r = std::strtok(q + 1, ":"); - r; - r = std::strtok(NULL, ":")) { - string_map::iterator i = set_tag(r, none, overwrite_existing); - (*i).second.second = true; + r; + r = std::strtok(NULL, ":")) { + string_map::iterator i = set_tag(r, none, overwrite_existing); + (*i).second.second = true; } } else if (q[len - 1] == ':') { // a metadata setting - tag = string(q, len - 1); + int index = 1; + if (q[len - 2] == ':') { + by_value = true; + index = 2; + } + tag = string(q, len - index); } } } -void item_t::append_note(const char * p, bool overwrite_existing, - optional<date_t::year_type> current_year) +void item_t::append_note(const char * p, + scope_t& scope, + bool overwrite_existing, + optional<date_t::year_type> current_year) { if (note) { *note += '\n'; @@ -194,7 +215,7 @@ void item_t::append_note(const char * p, bool overwrite_existing, note = p; } - parse_tags(p, overwrite_existing, current_year); + parse_tags(p, scope, overwrite_existing, current_year); } namespace { @@ -235,21 +256,21 @@ namespace { if (args.size() == 1) { if (args[0].is_string()) - return item.has_tag(args[0].as_string()); + return item.has_tag(args[0].as_string()); else if (args[0].is_mask()) - return item.has_tag(args[0].as_mask()); + return item.has_tag(args[0].as_mask()); else - throw_(std::runtime_error, - _("Expected string or mask for argument 1, but received %1") - << args[0].label()); + throw_(std::runtime_error, + _("Expected string or mask for argument 1, but received %1") + << args[0].label()); } else if (args.size() == 2) { if (args[0].is_mask() && args[1].is_mask()) - return item.has_tag(args[0].to_mask(), args[1].to_mask()); + return item.has_tag(args[0].to_mask(), args[1].to_mask()); else - throw_(std::runtime_error, - _("Expected masks for arguments 1 and 2, but received %1 and %2") - << args[0].label() << args[1].label()); + throw_(std::runtime_error, + _("Expected masks for arguments 1 and 2, but received %1 and %2") + << args[0].label() << args[1].label()); } else if (args.size() == 0) { throw_(std::runtime_error, _("Too few arguments to function")); @@ -263,25 +284,25 @@ namespace { value_t get_tag(call_scope_t& args) { item_t& item(find_scope<item_t>(args)); - optional<string> str; + optional<value_t> val; if (args.size() == 1) { if (args[0].is_string()) - str = item.get_tag(args[0].as_string()); + val = item.get_tag(args[0].as_string()); else if (args[0].is_mask()) - str = item.get_tag(args[0].as_mask()); + val = item.get_tag(args[0].as_mask()); else - throw_(std::runtime_error, - _("Expected string or mask for argument 1, but received %1") - << args[0].label()); + throw_(std::runtime_error, + _("Expected string or mask for argument 1, but received %1") + << args[0].label()); } else if (args.size() == 2) { if (args[0].is_mask() && args[1].is_mask()) - str = item.get_tag(args[0].to_mask(), args[1].to_mask()); + val = item.get_tag(args[0].to_mask(), args[1].to_mask()); else - throw_(std::runtime_error, - _("Expected masks for arguments 1 and 2, but received %1 and %2") - << args[0].label() << args[1].label()); + throw_(std::runtime_error, + _("Expected masks for arguments 1 and 2, but received %1 and %2") + << args[0].label() << args[1].label()); } else if (args.size() == 0) { throw_(std::runtime_error, _("Too few arguments to function")); @@ -290,10 +311,7 @@ namespace { throw_(std::runtime_error, _("Too many arguments to function")); } - if (str) - return string_value(*str); - else - return NULL_VALUE; + return val ? *val : NULL_VALUE; } value_t get_pathname(item_t& item) { @@ -355,13 +373,13 @@ value_t get_comment(item_t& item) bool need_separator = false; for (const char * p = item.note->c_str(); *p; p++) { if (*p == '\n') { - need_separator = true; + need_separator = true; } else { - if (need_separator) { - buf << "\n ;"; - need_separator = false; - } - buf << *p; + if (need_separator) { + buf << "\n ;"; + need_separator = false; + } + buf << *p; } } return string_value(buf.str()); @@ -369,7 +387,7 @@ value_t get_comment(item_t& item) } expr_t::ptr_op_t item_t::lookup(const symbol_t::kind_t kind, - const string& name) + const string& name) { if (kind != symbol_t::FUNCTION) return NULL; @@ -502,7 +520,7 @@ bool item_t::valid() const void print_item(std::ostream& out, const item_t& item, const string& prefix) { out << source_context(item.pos->pathname, item.pos->beg_pos, - item.pos->end_pos, prefix); + item.pos->end_pos, prefix); } string item_context(const item_t& item, const string& desc) @@ -528,7 +546,7 @@ string item_context(const item_t& item, const string& desc) if (item.pos->beg_line != item.pos->end_line) out << _(", lines ") << item.pos->beg_line << "-" - << item.pos->end_line << ":\n"; + << item.pos->end_line << ":\n"; else out << _(", line ") << item.pos->beg_line << ":\n"; @@ -50,10 +50,10 @@ struct position_t { path pathname; istream_pos_type beg_pos; - std::size_t beg_line; + std::size_t beg_line; istream_pos_type end_pos; - std::size_t end_line; - std::size_t sequence; + std::size_t end_line; + std::size_t sequence; position_t() : beg_pos(0), beg_line(0), end_pos(0), end_line(0), sequence(0) { @@ -97,19 +97,19 @@ private: #endif // HAVE_BOOST_SERIALIZATION }; -class item_t : public supports_flags<>, public scope_t +class item_t : public supports_flags<uint_least16_t>, public scope_t { public: -#define ITEM_NORMAL 0x00 // no flags at all, a basic posting -#define ITEM_GENERATED 0x01 // posting was not found in a journal -#define ITEM_TEMP 0x02 // posting is a managed temporary +#define ITEM_NORMAL 0x00 // no flags at all, a basic posting +#define ITEM_GENERATED 0x01 // posting was not found in a journal +#define ITEM_TEMP 0x02 // posting is a managed temporary enum state_t { UNCLEARED = 0, CLEARED, PENDING }; - typedef std::pair<optional<string>, bool> tag_data_t; - typedef std::map<string, tag_data_t> string_map; + typedef std::pair<optional<value_t>, bool> tag_data_t; + typedef std::map<string, tag_data_t> string_map; - state_t _state; + state_t _state; optional<date_t> _date; optional<date_t> _date_eff; optional<string> note; @@ -117,11 +117,11 @@ public: optional<string_map> metadata; item_t(flags_t _flags = ITEM_NORMAL, const optional<string>& _note = none) - : supports_flags<>(_flags), _state(UNCLEARED), note(_note) + : supports_flags<uint_least16_t>(_flags), _state(UNCLEARED), note(_note) { TRACE_CTOR(item_t, "flags_t, const string&"); } - item_t(const item_t& item) : supports_flags<>(), scope_t() + item_t(const item_t& item) : supports_flags<uint_least16_t>(), scope_t() { TRACE_CTOR(item_t, "copy"); copy_details(item); @@ -151,21 +151,25 @@ public: virtual bool has_tag(const string& tag) const; virtual bool has_tag(const mask_t& tag_mask, - const optional<mask_t>& value_mask = none) const; + const optional<mask_t>& value_mask = none) const; - virtual optional<string> get_tag(const string& tag) const; - virtual optional<string> get_tag(const mask_t& tag_mask, - const optional<mask_t>& value_mask = none) const; + virtual optional<value_t> get_tag(const string& tag) const; + virtual optional<value_t> get_tag(const mask_t& tag_mask, + const optional<mask_t>& value_mask = none) const; virtual string_map::iterator - set_tag(const string& tag, - const optional<string>& value = none, - const bool overwrite_existing = true); - - virtual void parse_tags(const char * p, bool overwrite_existing = true, - optional<date_t::year_type> current_year = none); - virtual void append_note(const char * p, bool overwrite_existing = true, - optional<date_t::year_type> current_year = none); + set_tag(const string& tag, + const optional<value_t>& value = none, + const bool overwrite_existing = true); + + virtual void parse_tags(const char * p, + scope_t& scope, + bool overwrite_existing = true, + optional<date_t::year_type> current_year = none); + virtual void append_note(const char * p, + scope_t& scope, + bool overwrite_existing = true, + optional<date_t::year_type> current_year = none); static bool use_effective_date; @@ -173,7 +177,7 @@ public: assert(_date); if (use_effective_date) if (optional<date_t> effective = effective_date()) - return *effective; + return *effective; return *_date; } virtual date_t actual_date() const { @@ -192,7 +196,7 @@ public: } virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name); + const string& name); bool valid() const; @@ -204,7 +208,7 @@ private: template<class Archive> void serialize(Archive& ar, const unsigned int /* version */) { - ar & boost::serialization::base_object<supports_flags<> >(*this); + ar & boost::serialization::base_object<supports_flags<uint_least16_t> >(*this); ar & boost::serialization::base_object<scope_t>(*this); ar & _state; ar & _date; @@ -217,9 +221,9 @@ private: }; value_t get_comment(item_t& item); -void print_item(std::ostream& out, const item_t& item, - const string& prefix = ""); -string item_context(const item_t& item, const string& desc); +void print_item(std::ostream& out, const item_t& item, + const string& prefix = ""); +string item_context(const item_t& item, const string& desc); } // namespace ledger diff --git a/src/iterators.cc b/src/iterators.cc index ade1d4b3..b63a10e9 100644 --- a/src/iterators.cc +++ b/src/iterators.cc @@ -91,47 +91,47 @@ void posts_commodities_iterator::reset(journal_t& journal) foreach (commodity_t * comm, commodities) { if (optional<commodity_t::varied_history_t&> history = - comm->varied_history()) { + comm->varied_history()) { account_t * account = journal.master->find_account(comm->symbol()); foreach (commodity_t::history_by_commodity_map::value_type& pair, - history->histories) { - foreach (commodity_t::history_map::value_type& hpair, - pair.second.prices) { - xact_t * xact; - string symbol = hpair.second.commodity().symbol(); - - std::map<string, xact_t *>::iterator i = - xacts_by_commodity.find(symbol); - if (i != xacts_by_commodity.end()) { - xact = (*i).second; - } else { - xact = &temps.create_xact(); - xact_temps.push_back(xact); - xact->payee = symbol; - xact->_date = hpair.first.date(); - xacts_by_commodity.insert - (std::pair<string, xact_t *>(symbol, xact)); - } - - bool post_already_exists = false; - - foreach (post_t * post, xact->posts) { - if (post->_date == hpair.first.date() && - post->amount == hpair.second) { - post_already_exists = true; - break; - } - } - - if (! post_already_exists) { - post_t& temp = temps.create_post(*xact, account); - temp._date = hpair.first.date(); - temp.amount = hpair.second; - - temp.xdata().datetime = hpair.first; - } - } + history->histories) { + foreach (commodity_t::history_map::value_type& hpair, + pair.second.prices) { + xact_t * xact; + string symbol = hpair.second.commodity().symbol(); + + std::map<string, xact_t *>::iterator i = + xacts_by_commodity.find(symbol); + if (i != xacts_by_commodity.end()) { + xact = (*i).second; + } else { + xact = &temps.create_xact(); + xact_temps.push_back(xact); + xact->payee = symbol; + xact->_date = hpair.first.date(); + xacts_by_commodity.insert + (std::pair<string, xact_t *>(symbol, xact)); + } + + bool post_already_exists = false; + + foreach (post_t * post, xact->posts) { + if (post->_date == hpair.first.date() && + post->amount == hpair.second) { + post_already_exists = true; + break; + } + } + + if (! post_already_exists) { + post_t& temp = temps.create_post(*xact, account); + temp._date = hpair.first.date(); + temp.amount = hpair.second; + + temp.xdata().datetime = hpair.first; + } + } } } } @@ -162,7 +162,7 @@ post_t * posts_commodities_iterator::operator()() account_t * basic_accounts_iterator::operator()() { while (! accounts_i.empty() && - accounts_i.back() == accounts_end.back()) { + accounts_i.back() == accounts_end.back()) { accounts_i.pop_back(); accounts_end.pop_back(); } @@ -187,14 +187,14 @@ void sorted_accounts_iterator::push_back(account_t& account) push_all(account, accounts_list.back()); std::stable_sort(accounts_list.back().begin(), - accounts_list.back().end(), - compare_items<account_t>(sort_cmp)); + accounts_list.back().end(), + compare_items<account_t>(sort_cmp)); #if defined(DEBUG_ON) if (SHOW_DEBUG("accounts.sorted")) { foreach (account_t * account, accounts_list.back()) - DEBUG("accounts.sorted", - "Account (flat): " << account->fullname()); + DEBUG("accounts.sorted", + "Account (flat): " << account->fullname()); } #endif } else { @@ -206,7 +206,7 @@ void sorted_accounts_iterator::push_back(account_t& account) } void sorted_accounts_iterator::push_all(account_t& account, - accounts_deque_t& deque) + accounts_deque_t& deque) { foreach (accounts_map::value_type& pair, account.accounts) { deque.push_back(pair.second); @@ -215,13 +215,13 @@ void sorted_accounts_iterator::push_all(account_t& account, } void sorted_accounts_iterator::sort_accounts(account_t& account, - accounts_deque_t& deque) + accounts_deque_t& deque) { foreach (accounts_map::value_type& pair, account.accounts) deque.push_back(pair.second); std::stable_sort(deque.begin(), deque.end(), - compare_items<account_t>(sort_cmp)); + compare_items<account_t>(sort_cmp)); #if defined(DEBUG_ON) if (SHOW_DEBUG("accounts.sorted")) { @@ -234,7 +234,7 @@ void sorted_accounts_iterator::sort_accounts(account_t& account, account_t * sorted_accounts_iterator::operator()() { while (! sorted_accounts_i.empty() && - sorted_accounts_i.back() == sorted_accounts_end.back()) { + sorted_accounts_i.back() == sorted_accounts_end.back()) { sorted_accounts_i.pop_back(); sorted_accounts_end.pop_back(); assert(! accounts_list.empty()); diff --git a/src/iterators.h b/src/iterators.h index 5e9f5fbe..5113d3b2 100644 --- a/src/iterators.h +++ b/src/iterators.h @@ -142,8 +142,8 @@ class posts_commodities_iterator : public posts_iterator { protected: journal_posts_iterator journal_posts; - xacts_iterator xacts; - xact_posts_iterator posts; + xacts_iterator xacts; + xact_posts_iterator posts; temporaries_t temps; xacts_list xact_temps; @@ -203,13 +203,13 @@ class sorted_accounts_iterator : public accounts_iterator typedef std::deque<account_t *> accounts_deque_t; - std::list<accounts_deque_t> accounts_list; + std::list<accounts_deque_t> accounts_list; std::list<accounts_deque_t::const_iterator> sorted_accounts_i; std::list<accounts_deque_t::const_iterator> sorted_accounts_end; public: sorted_accounts_iterator(account_t& account, - const expr_t& _sort_cmp, bool _flatten_all) + const expr_t& _sort_cmp, bool _flatten_all) : sort_cmp(_sort_cmp), flatten_all(_flatten_all) { TRACE_CTOR(sorted_accounts_iterator, "const expr_t&, bool, account_t&"); push_back(account); diff --git a/src/journal.cc b/src/journal.cc index 158fac42..fd6d3eac 100644 --- a/src/journal.cc +++ b/src/journal.cc @@ -145,9 +145,9 @@ bool journal_t::remove_xact(xact_t * xact) } std::size_t journal_t::read(std::istream& in, - const path& pathname, - account_t * master_alt, - scope_t * scope) + const path& pathname, + account_t * master_alt, + scope_t * scope) { std::size_t count = 0; try { @@ -156,13 +156,13 @@ std::size_t journal_t::read(std::istream& in, if (! scope) throw_(std::runtime_error, - _("No default scope in which to read journal file '%1'") - << pathname); + _("No default scope in which to read journal file '%1'") + << pathname); value_t strict = expr_t("strict").calc(*scope); count = parse(in, *scope, master_alt ? master_alt : master, - &pathname, strict.to_boolean()); + &pathname, strict.to_boolean()); } catch (...) { clear_xdata(); @@ -178,14 +178,14 @@ std::size_t journal_t::read(std::istream& in, } std::size_t journal_t::read(const path& pathname, - account_t * master, - scope_t * scope) + account_t * master, + scope_t * scope) { path filename = resolve_path(pathname); if (! exists(filename)) throw_(std::runtime_error, - _("Cannot read journal file '%1'") << filename); + _("Cannot read journal file '%1'") << filename); ifstream stream(filename); std::size_t count = read(stream, filename, master, scope); diff --git a/src/journal.h b/src/journal.h index a407c02c..ca6b6e4f 100644 --- a/src/journal.h +++ b/src/journal.h @@ -55,7 +55,7 @@ class period_xact_t; class account_t; class scope_t; -typedef std::list<xact_t *> xacts_list; +typedef std::list<xact_t *> xacts_list; typedef std::list<auto_xact_t *> auto_xacts_list; typedef std::list<period_xact_t *> period_xacts_list; @@ -70,9 +70,9 @@ public: struct fileinfo_t { optional<path> filename; - uintmax_t size; - datetime_t modtime; - bool from_stream; + uintmax_t size; + datetime_t modtime; + bool from_stream; fileinfo_t() : size(0), from_stream(true) { TRACE_CTOR(journal_t::fileinfo_t, ""); @@ -85,7 +85,7 @@ public: } fileinfo_t(const fileinfo_t& info) : filename(info.filename), size(info.size), - modtime(info.modtime), from_stream(info.from_stream) + modtime(info.modtime), from_stream(info.from_stream) { TRACE_CTOR(journal_t::fileinfo_t, "copy"); } @@ -109,11 +109,11 @@ public: #endif // HAVE_BOOST_SERIALIZATION }; - account_t * master; - account_t * bucket; - xacts_list xacts; - auto_xacts_list auto_xacts; - period_xacts_list period_xacts; + account_t * master; + account_t * bucket; + xacts_list xacts; + auto_xacts_list auto_xacts; + period_xacts_list period_xacts; std::list<fileinfo_t> sources; payee_mappings_t payee_mappings; account_mappings_t account_mappings; @@ -135,8 +135,8 @@ public: // These four methods are delegated to the current session, since all // accounts processed are gathered together at the session level. - void add_account(account_t * acct); - bool remove_account(account_t * acct); + void add_account(account_t * acct); + bool remove_account(account_t * acct); account_t * find_account(const string& name, bool auto_create = true); account_t * find_account_re(const string& regexp); @@ -164,18 +164,18 @@ public: } std::size_t read(std::istream& in, - const path& pathname, - account_t * master = NULL, - scope_t * scope = NULL); - std::size_t read(const path& pathname, - account_t * master = NULL, - scope_t * scope = NULL); + const path& pathname, + account_t * master = NULL, + scope_t * scope = NULL); + std::size_t read(const path& pathname, + account_t * master = NULL, + scope_t * scope = NULL); std::size_t parse(std::istream& in, - scope_t& session_scope, - account_t * master = NULL, - const path * original_file = NULL, - bool strict = false); + scope_t& session_scope, + account_t * master = NULL, + const path * original_file = NULL, + bool strict = false); bool has_xdata(); void clear_xdata(); diff --git a/src/lookup.cc b/src/lookup.cc index 40b6c185..221397ca 100644 --- a/src/lookup.cc +++ b/src/lookup.cc @@ -43,7 +43,7 @@ namespace { struct score_sorter { bool operator()(const score_entry_t& left, - const score_entry_t& right) const { + const score_entry_t& right) const { return left.second > right.second; } }; @@ -53,7 +53,7 @@ namespace { struct usage_sorter { bool operator()(const account_use_pair& left, - const account_use_pair& right) const { + const account_use_pair& right) const { return left.second > right.second; } }; @@ -61,8 +61,8 @@ namespace { std::pair<xact_t *, account_t *> lookup_probable_account(const string& ident, - xacts_iterator& iter_func, - account_t * ref_account) + xacts_iterator& iter_func, + account_t * ref_account) { scorecard_t scores; @@ -76,11 +76,11 @@ lookup_probable_account(const string& ident, #endif DEBUG("lookup.account", - "Looking up identifier '" << lowered_ident.extract() << "'"); + "Looking up identifier '" << lowered_ident.extract() << "'"); #if defined(DEBUG_ON) if (ref_account != NULL) DEBUG("lookup.account", - " with reference account: " << ref_account->fullname()); + " with reference account: " << ref_account->fullname()); #endif while (xact_t * xact = iter_func()) { @@ -109,17 +109,17 @@ lookup_probable_account(const string& ident, DEBUG("lookup", "Considering payee: " << value_key.extract()); - std::size_t index = 0; - std::size_t last_match_pos = unistring::npos; - int bonus = 0; - int score = 0; - std::size_t pos; + std::size_t index = 0; + std::size_t last_match_pos = unistring::npos; + int bonus = 0; + int score = 0; + std::size_t pos; char_positions_map positions; // Walk each letter in the source identifier foreach (const uint32_t& ch, lowered_ident.utf32chars) { - int addend = 0; - bool added_bonus = false; + int addend = 0; + bool added_bonus = false; std::size_t value_len = value_key.length(); pos = value_key.find(ch); @@ -131,76 +131,76 @@ lookup_probable_account(const string& ident, char_positions_map::iterator pi = positions.find(ch); while (pi != positions.end() && - pos != unistring::npos && pos <= (*pi).second && - (*pi).second + 1 < value_len) - pos = value_key.find(ch, (*pi).second + 1); + pos != unistring::npos && pos <= (*pi).second && + (*pi).second + 1 < value_len) + pos = value_key.find(ch, (*pi).second + 1); if (pos != unistring::npos) { - if (pi != positions.end()) - (*pi).second = pos; - else - positions.insert(char_positions_map::value_type(ch, pos)); - - // If it occurs in the same order as the source identifier -- that is, - // without intervening letters to break the pattern -- it's worth 10 - // points. Plus, an extra point is added for every letter in chains - // of 3 or more. - - if (last_match_pos == unistring::npos ? - index == 0 && pos == 0 : pos == last_match_pos + 1) { - DEBUG("lookup", - " char " << index << " in-sequence match with bonus " << bonus); - addend += 10; - if (bonus > 2) - addend += bonus - 2; - bonus++; - added_bonus = true; - - last_match_pos = pos; - } - - // If it occurs in the same general sequence as the source identifier, - // it's worth 5 points, plus an extra point if it's within the next 3 - // characters, and an extra point if it's preceded by a non-alphabetic - // character. - // - // If the letter occurs at all in the target identifier, it's worth 1 - // point, plus an extra point if it's within 3 characters, and an - // extra point if it's preceded by a non-alphabetic character. - - else { - bool in_order_match = (last_match_pos != unistring::npos && - pos > last_match_pos); - DEBUG("lookup", " char " << index << " " << - (in_order_match ? "in-order" : "out-of-order") - << " match" << (in_order_match && pos - index < 3 ? - " with proximity bonus of 1" : "")); - - if (pos < index) - addend += 1; - else - addend += 5; - - if (in_order_match && pos - index < 3) - addend++; + if (pi != positions.end()) + (*pi).second = pos; + else + positions.insert(char_positions_map::value_type(ch, pos)); + + // If it occurs in the same order as the source identifier -- that is, + // without intervening letters to break the pattern -- it's worth 10 + // points. Plus, an extra point is added for every letter in chains + // of 3 or more. + + if (last_match_pos == unistring::npos ? + index == 0 && pos == 0 : pos == last_match_pos + 1) { + DEBUG("lookup", + " char " << index << " in-sequence match with bonus " << bonus); + addend += 10; + if (bonus > 2) + addend += bonus - 2; + bonus++; + added_bonus = true; + + last_match_pos = pos; + } + + // If it occurs in the same general sequence as the source identifier, + // it's worth 5 points, plus an extra point if it's within the next 3 + // characters, and an extra point if it's preceded by a non-alphabetic + // character. + // + // If the letter occurs at all in the target identifier, it's worth 1 + // point, plus an extra point if it's within 3 characters, and an + // extra point if it's preceded by a non-alphabetic character. + + else { + bool in_order_match = (last_match_pos != unistring::npos && + pos > last_match_pos); + DEBUG("lookup", " char " << index << " " << + (in_order_match ? "in-order" : "out-of-order") + << " match" << (in_order_match && pos - index < 3 ? + " with proximity bonus of 1" : "")); + + if (pos < index) + addend += 1; + else + addend += 5; + + if (in_order_match && pos - index < 3) + addend++; #if !defined(HAVE_BOOST_REGEX_UNICODE) - if (pos == 0 || (pos > 0 && !std::isalnum(value_key[pos - 1]))) - addend++; + if (pos == 0 || (pos > 0 && !std::isalnum(value_key[pos - 1]))) + addend++; #else - // jww (2010-03-07): Not yet implemented + // jww (2010-03-07): Not yet implemented #endif - last_match_pos = pos; - } + last_match_pos = pos; + } // If the letter does not appear at all, decrease the score by 1 } else { - last_match_pos = unistring::npos; + last_match_pos = unistring::npos; - DEBUG("lookup", " char " << index << " does not match"); - addend--; + DEBUG("lookup", " char " << index << " does not match"); + addend--; } // Finally, decay what is to be added to the score based on its position @@ -211,9 +211,9 @@ lookup_probable_account(const string& ident, // divisor for the addend. if ((int(index / 5) + 1) > 1) { - DEBUG("lookup", - " discounting the addend by / " << (int(index / 5) + 1)); - addend = int(double(addend) / (int(index / 5) + 1)); + DEBUG("lookup", + " discounting the addend by / " << (int(index / 5) + 1)); + addend = int(double(addend) / (int(index / 5) + 1)); } DEBUG("lookup", " final addend is " << addend); @@ -221,7 +221,7 @@ lookup_probable_account(const string& ident, DEBUG("lookup", " score is " << score); if (! added_bonus) - bonus = 0; + bonus = 0; index++; } @@ -238,26 +238,26 @@ lookup_probable_account(const string& ident, std::stable_sort(scores.begin(), scores.end(), score_sorter()); - scorecard_t::iterator si = scores.begin(); - int decay = 0; - xact_t * best_xact = si != scores.end() ? (*si).first : NULL; - account_use_map account_usage; + scorecard_t::iterator si = scores.begin(); + int decay = 0; + xact_t * best_xact = si != scores.end() ? (*si).first : NULL; + account_use_map account_usage; for (int i = 0; i < 5 && si != scores.end(); i++, si++) { DEBUG("lookup.account", - "Payee: " << std::setw(5) << std::right << (*si).second << - " - " << (*si).first->payee); + "Payee: " << std::setw(5) << std::right << (*si).second << + " - " << (*si).first->payee); foreach (post_t * post, (*si).first->posts) { if (! post->has_flags(ITEM_TEMP | ITEM_GENERATED) && - post->account != ref_account && - ! post->account->has_flags(ACCOUNT_TEMP | ACCOUNT_GENERATED)) { - account_use_map::iterator x = account_usage.find(post->account); - if (x == account_usage.end()) - account_usage.insert(account_use_pair(post->account, - ((*si).second - decay))); - else - (*x).second += ((*si).second - decay); + post->account != ref_account && + ! post->account->has_flags(ACCOUNT_TEMP | ACCOUNT_GENERATED)) { + account_use_map::iterator x = account_usage.find(post->account); + if (x == account_usage.end()) + account_usage.insert(account_use_pair(post->account, + ((*si).second - decay))); + else + (*x).second += ((*si).second - decay); } decay++; } @@ -267,14 +267,14 @@ lookup_probable_account(const string& ident, #if defined(DEBUG_ON) if (SHOW_DEBUG("lookup.account")) { foreach (const account_use_pair& value, account_usage) { - DEBUG("lookup.account", - "Account: " << value.second << " - " << value.first->fullname()); + DEBUG("lookup.account", + "Account: " << value.second << " - " << value.first->fullname()); } } #endif return std::pair<xact_t *, account_t *> (best_xact, (*std::max_element(account_usage.begin(), account_usage.end(), - usage_sorter())).first); + usage_sorter())).first); } else { return std::pair<xact_t *, account_t *>(best_xact, NULL); } diff --git a/src/lookup.h b/src/lookup.h index 53cb5837..7776be80 100644 --- a/src/lookup.h +++ b/src/lookup.h @@ -48,8 +48,8 @@ namespace ledger { std::pair<xact_t *, account_t *> lookup_probable_account(const string& ident, - xacts_iterator& iter_func, - account_t * ref_account = NULL); + xacts_iterator& iter_func, + account_t * ref_account = NULL); } // namespace ledger diff --git a/src/main.cc b/src/main.cc index 23593533..e0da3a25 100644 --- a/src/main.cc +++ b/src/main.cc @@ -31,8 +31,8 @@ #include <system.hh> -#include "global.h" // This is where the meat of main() is, which - // was moved there for the sake of clarity here +#include "global.h" // This is where the meat of main() is, which + // was moved there for the sake of clarity here #include "session.h" using namespace ledger; @@ -103,13 +103,13 @@ int main(int argc, char * argv[], char * envp[]) ifstream in(global_scope->HANDLER(script_).str()); while (status == 0 && ! in.eof()) { - char line[1024]; - in.getline(line, 1023); + char line[1024]; + in.getline(line, 1023); - char * p = skip_ws(line); - if (*p && *p != '#') - status = global_scope->execute_command_wrapper(split_arguments(p), - true); + char * p = skip_ws(line); + if (*p && *p != '#') + status = global_scope->execute_command_wrapper(split_arguments(p), + true); } } else if (! args.empty()) { @@ -133,53 +133,53 @@ int main(int argc, char * argv[], char * envp[]) #endif while (char * p = readline(global_scope->prompt_string())) { - char * expansion = NULL; - int result; - - result = history_expand(skip_ws(p), &expansion); - - if (result < 0 || result == 2) { - if (expansion) - std::free(expansion); - std::free(p); - throw_(std::logic_error, - _("Failed to expand history reference '%1'") << p); - } - else if (expansion) { - add_history(expansion); - } + char * expansion = NULL; + int result; + + result = history_expand(skip_ws(p), &expansion); + + if (result < 0 || result == 2) { + if (expansion) + std::free(expansion); + std::free(p); + throw_(std::logic_error, + _("Failed to expand history reference '%1'") << p); + } + else if (expansion) { + add_history(expansion); + } #else // HAVE_LIBEDIT while (! std::cin.eof()) { - std::cout << global_scope->prompt_string(); - char line[1024]; - std::cin.getline(line, 1023); + std::cout << global_scope->prompt_string(); + char line[1024]; + std::cin.getline(line, 1023); - char * p = skip_ws(line); + char * p = skip_ws(line); #endif // HAVE_LIBEDIT - check_for_signal(); + check_for_signal(); - if (*p && *p != '#') { - if (std::strncmp(p, "quit", 4) == 0) - exit_loop = true; - else - global_scope->execute_command_wrapper(split_arguments(p), true); - } + if (*p && *p != '#') { + if (std::strncmp(p, "quit", 4) == 0) + exit_loop = true; + else + global_scope->execute_command_wrapper(split_arguments(p), true); + } #ifdef HAVE_LIBEDIT - if (expansion) - std::free(expansion); - std::free(p); + if (expansion) + std::free(expansion); + std::free(p); #endif - if (exit_loop) - break; + if (exit_loop) + break; } - status = 0; // report success + status = 0; // report success } } catch (const std::exception& err) { @@ -187,11 +187,11 @@ int main(int argc, char * argv[], char * envp[]) global_scope->report_error(err); else std::cerr << "Exception during initialization: " << err.what() - << std::endl; + << std::endl; } catch (int _status) { - status = _status; // used for a "quick" exit, and is used only - // if help text (such as --help) was displayed + status = _status; // used for a "quick" exit, and is used only + // if help text (such as --help) was displayed } // If memory verification is being performed (which can be very slow), clean diff --git a/src/mask.cc b/src/mask.cc index cd516fe2..52907cfe 100644 --- a/src/mask.cc +++ b/src/mask.cc @@ -66,17 +66,17 @@ mask_t& mask_t::assign_glob(const string& pat) break; case '[': while (i < len && pat[i] != ']') - re_pat += pat[i++]; + re_pat += pat[i++]; if (i < len) - re_pat += pat[i]; + re_pat += pat[i]; break; case '\\': if (i + 1 < len) { - re_pat += pat[++i]; - break; + re_pat += pat[++i]; + break; } else { - // fallthrough... + // fallthrough... } default: re_pat += pat[i]; @@ -85,13 +85,13 @@ public: bool match(const string& text) const { #if defined(HAVE_BOOST_REGEX_UNICODE) DEBUG("mask.match", - "Matching: \"" << text << "\" =~ /" << str() << "/ = " - << (boost::u32regex_search(text, expr) ? "true" : "false")); + "Matching: \"" << text << "\" =~ /" << str() << "/ = " + << (boost::u32regex_search(text, expr) ? "true" : "false")); return boost::u32regex_search(text, expr); #else DEBUG("mask.match", - "Matching: \"" << text << "\" =~ /" << str() << "/ = " - << (boost::regex_search(text, expr) ? "true" : "false")); + "Matching: \"" << text << "\" =~ /" << str() << "/ = " + << (boost::regex_search(text, expr) ? "true" : "false")); return boost::regex_search(text, expr); #endif } @@ -107,7 +107,7 @@ public: unistring ustr; std::basic_string<UChar32> expr_str = expr.str(); std::copy(expr_str.begin(), expr_str.end(), - std::back_inserter(ustr.utf32chars)); + std::back_inserter(ustr.utf32chars)); return ustr.extract(); #else return expr.str(); @@ -40,7 +40,7 @@ namespace ledger { namespace { value_t split_cons_expr(expr_t::ptr_op_t op, scope_t& scope, - std::vector<expr_t>& exprs) + std::vector<expr_t>& exprs) { value_t seq; @@ -50,16 +50,16 @@ namespace { expr_t::ptr_op_t next = op->right(); while (next) { - expr_t::ptr_op_t value_op; - if (next->kind == expr_t::op_t::O_CONS) { - value_op = next->left(); - next = next->right(); - } else { - value_op = next; - next = NULL; - } - exprs.push_back(expr_t(value_op, &scope)); - seq.push_back(value_t(exprs.back())); + expr_t::ptr_op_t value_op; + if (next->kind == expr_t::op_t::O_CONS) { + value_op = next->left(); + next = next->right(); + } else { + value_op = next; + next = NULL; + } + exprs.push_back(expr_t(value_op, &scope)); + seq.push_back(value_t(exprs.back())); } } else { exprs.push_back(expr_t(op, &scope)); @@ -80,8 +80,8 @@ expr_t::ptr_op_t expr_t::op_t::compile(scope_t& scope, const int depth) // not be found there. #if defined(DEBUG_ON) if (SHOW_DEBUG("expr.compile")) { - DEBUG("expr.compile", "Found definition:"); - def->dump(*_log_stream, 0); + DEBUG("expr.compile", "Found definition:"); + def->dump(*_log_stream, 0); } #endif // defined(DEBUG_ON) return copy(def); @@ -102,9 +102,9 @@ expr_t::ptr_op_t expr_t::op_t::compile(scope_t& scope, const int depth) break; case O_CALL: if (left()->left()->is_ident()) - scope.define(symbol_t::FUNCTION, left()->left()->as_ident(), this); + scope.define(symbol_t::FUNCTION, left()->left()->as_ident(), this); else - throw_(compile_error, _("Invalid function definition")); + throw_(compile_error, _("Invalid function definition")); break; default: throw_(compile_error, _("Invalid function definition")); @@ -114,8 +114,8 @@ expr_t::ptr_op_t expr_t::op_t::compile(scope_t& scope, const int depth) ptr_op_t lhs(left()->compile(scope, depth)); ptr_op_t rhs(kind > UNARY_OPERATORS && has_right() ? - (kind == O_LOOKUP ? right() : - right()->compile(scope, depth)) : NULL); + (kind == O_LOOKUP ? right() : + right()->compile(scope, depth)) : NULL); if (lhs == left() && (! rhs || rhs == right())) return this; @@ -170,31 +170,31 @@ value_t expr_t::op_t::calc(scope_t& scope, ptr_op_t * locus, const int depth) case O_DEFINE: { call_scope_t& call_args(downcast<call_scope_t>(scope)); - std::size_t args_count = call_args.size(); - std::size_t args_index = 0; + std::size_t args_count = call_args.size(); + std::size_t args_index = 0; assert(left()->kind == O_CALL); for (ptr_op_t sym = left()->right(); - sym; - sym = sym->has_right() ? sym->right() : NULL) { + sym; + sym = sym->has_right() ? sym->right() : NULL) { ptr_op_t varname = sym; if (sym->kind == O_CONS) - varname = sym->left(); + varname = sym->left(); if (! varname->is_ident()) - throw_(calc_error, _("Invalid function definition")); + throw_(calc_error, _("Invalid function definition")); else if (args_index == args_count) - scope.define(symbol_t::FUNCTION, varname->as_ident(), - wrap_value(false)); + scope.define(symbol_t::FUNCTION, varname->as_ident(), + wrap_value(false)); else - scope.define(symbol_t::FUNCTION, varname->as_ident(), - wrap_value(call_args[args_index++])); + scope.define(symbol_t::FUNCTION, varname->as_ident(), + wrap_value(call_args[args_index++])); } if (args_index < args_count) throw_(calc_error, - _("Too many arguments in function call (saw %1)") << args_count); + _("Too many arguments in function call (saw %1)") << args_count); result = right()->calc(scope, locus, depth + 1); break; @@ -203,24 +203,24 @@ value_t expr_t::op_t::calc(scope_t& scope, ptr_op_t * locus, const int depth) case O_LOOKUP: if (value_t obj = left()->calc(scope, locus, depth + 1)) { if (obj.is_scope()) { - if (obj.as_scope() == NULL) { - throw_(calc_error, _("Left operand of . operator is NULL")); - } else { - scope_t& objscope(*obj.as_scope()); - if (ptr_op_t member = - objscope.lookup(symbol_t::FUNCTION, right()->as_ident())) { - result = member->calc(objscope, NULL, depth + 1); - break; - } - } + if (obj.as_scope() == NULL) { + throw_(calc_error, _("Left operand of . operator is NULL")); + } else { + scope_t& objscope(*obj.as_scope()); + if (ptr_op_t member = + objscope.lookup(symbol_t::FUNCTION, right()->as_ident())) { + result = member->calc(objscope, NULL, depth + 1); + break; + } + } } } if (right()->kind != IDENT) throw_(calc_error, - _("Right operand of . operator must be an identifier")); + _("Right operand of . operator must be an identifier")); else throw_(calc_error, - _("Failed to lookup member '%1'") << right()->as_ident()); + _("Failed to lookup member '%1'") << right()->as_ident()); break; case O_CALL: @@ -232,13 +232,13 @@ value_t expr_t::op_t::calc(scope_t& scope, ptr_op_t * locus, const int depth) if (has_right()) { if (kind == O_CALL) { - call_args.set_args(right()->calc(scope, locus, depth + 1)); + call_args.set_args(right()->calc(scope, locus, depth + 1)); } else { - // macros defer calculation to the callee - args_expr = std::vector<expr_t>(); - call_args.set_args(split_cons_expr(right()->kind == O_SEQ ? - right()->left() : right(), - scope, *args_expr)); + // macros defer calculation to the callee + args_expr = std::vector<expr_t>(); + call_args.set_args(split_cons_expr(right()->kind == O_SEQ ? + right()->left() : right(), + scope, *args_expr)); } } @@ -258,45 +258,45 @@ value_t expr_t::op_t::calc(scope_t& scope, ptr_op_t * locus, const int depth) case O_MATCH: result = (right()->calc(scope, locus, depth + 1).as_mask() - .match(left()->calc(scope, locus, depth + 1).to_string())); + .match(left()->calc(scope, locus, depth + 1).to_string())); break; case O_EQ: result = (left()->calc(scope, locus, depth + 1) == - right()->calc(scope, locus, depth + 1)); + right()->calc(scope, locus, depth + 1)); break; case O_LT: result = (left()->calc(scope, locus, depth + 1) < - right()->calc(scope, locus, depth + 1)); + right()->calc(scope, locus, depth + 1)); break; case O_LTE: result = (left()->calc(scope, locus, depth + 1) <= - right()->calc(scope, locus, depth + 1)); + right()->calc(scope, locus, depth + 1)); break; case O_GT: result = (left()->calc(scope, locus, depth + 1) > - right()->calc(scope, locus, depth + 1)); + right()->calc(scope, locus, depth + 1)); break; case O_GTE: result = (left()->calc(scope, locus, depth + 1) >= - right()->calc(scope, locus, depth + 1)); + right()->calc(scope, locus, depth + 1)); break; case O_ADD: result = (left()->calc(scope, locus, depth + 1) + - right()->calc(scope, locus, depth + 1)); + right()->calc(scope, locus, depth + 1)); break; case O_SUB: result = (left()->calc(scope, locus, depth + 1) - - right()->calc(scope, locus, depth + 1)); + right()->calc(scope, locus, depth + 1)); break; case O_MUL: result = (left()->calc(scope, locus, depth + 1) * - right()->calc(scope, locus, depth + 1)); + right()->calc(scope, locus, depth + 1)); break; case O_DIV: result = (left()->calc(scope, locus, depth + 1) / - right()->calc(scope, locus, depth + 1)); + right()->calc(scope, locus, depth + 1)); break; case O_NEG: @@ -345,16 +345,16 @@ value_t expr_t::op_t::calc(scope_t& scope, ptr_op_t * locus, const int depth) ptr_op_t next = right(); while (next) { - ptr_op_t value_op; - if (next->kind == O_CONS) { - value_op = next->left(); - next = next->right(); - } else { - value_op = next; - next = NULL; - } - temp.push_back(value_op->calc(scope, locus, depth + 1)); - DEBUG("op.cons", "temp now = " << temp); + ptr_op_t value_op; + if (next->kind == O_CONS) { + value_op = next->left(); + next = next->right(); + } else { + value_op = next; + next = NULL; + } + temp.push_back(value_op->calc(scope, locus, depth + 1)); + DEBUG("op.cons", "temp now = " << temp); } result = temp; } @@ -373,15 +373,15 @@ value_t expr_t::op_t::calc(scope_t& scope, ptr_op_t * locus, const int depth) if (has_right()) { ptr_op_t next = right(); while (next) { - ptr_op_t value_op; - if (next->kind == O_SEQ) { - value_op = next->left(); - next = next->right(); - } else { - value_op = next; - next = NULL; - } - result = value_op->calc(seq_scope, locus, depth + 1); + ptr_op_t value_op; + if (next->kind == O_SEQ) { + value_op = next->left(); + next = next->right(); + } else { + value_op = next; + next = NULL; + } + result = value_op->calc(seq_scope, locus, depth + 1); } } break; @@ -415,7 +415,7 @@ value_t expr_t::op_t::calc(scope_t& scope, ptr_op_t * locus, const int depth) namespace { bool print_cons(std::ostream& out, const expr_t::const_ptr_op_t op, - const expr_t::op_t::context_t& context) + const expr_t::op_t::context_t& context) { bool found = false; @@ -426,15 +426,15 @@ namespace { if (op->has_right()) { out << ", "; if (op->right()->kind == expr_t::op_t::O_CONS) - found = print_cons(out, op->right(), context); + found = print_cons(out, op->right(), context); else if (op->right()->print(out, context)) - found = true; + found = true; } return found; } bool print_seq(std::ostream& out, const expr_t::const_ptr_op_t op, - const expr_t::op_t::context_t& context) + const expr_t::op_t::context_t& context) { bool found = false; @@ -446,9 +446,9 @@ namespace { out << "; "; if (op->right()->kind == expr_t::op_t::O_CONS) - found = print_cons(out, op->right(), context); + found = print_cons(out, op->right(), context); else if (op->right()->print(out, context)) - found = true; + found = true; } return found; @@ -643,13 +643,13 @@ bool expr_t::op_t::print(std::ostream& out, const context_t& context) const found = true; if (has_right()) { if (right()->kind == O_SEQ) { - if (right()->print(out, context)) - found = true; + if (right()->print(out, context)) + found = true; } else { - out << "("; - if (has_right() && right()->print(out, context)) - found = true; - out << ")"; + out << "("; + if (has_right() && right()->print(out, context)) + found = true; + out << ")"; } } else { out << "()"; @@ -709,32 +709,32 @@ void expr_t::op_t::dump(std::ostream& out, const int depth) const case O_DEFINE: out << "O_DEFINE"; break; case O_LOOKUP: out << "O_LOOKUP"; break; - case O_CALL: out << "O_CALL"; break; + case O_CALL: out << "O_CALL"; break; case O_EXPAND: out << "O_EXPAND"; break; - case O_MATCH: out << "O_MATCH"; break; + case O_MATCH: out << "O_MATCH"; break; - case O_NOT: out << "O_NOT"; break; - case O_NEG: out << "O_NEG"; break; + case O_NOT: out << "O_NOT"; break; + case O_NEG: out << "O_NEG"; break; - case O_ADD: out << "O_ADD"; break; - case O_SUB: out << "O_SUB"; break; - case O_MUL: out << "O_MUL"; break; - case O_DIV: out << "O_DIV"; break; + case O_ADD: out << "O_ADD"; break; + case O_SUB: out << "O_SUB"; break; + case O_MUL: out << "O_MUL"; break; + case O_DIV: out << "O_DIV"; break; - case O_EQ: out << "O_EQ"; break; - case O_LT: out << "O_LT"; break; - case O_LTE: out << "O_LTE"; break; - case O_GT: out << "O_GT"; break; - case O_GTE: out << "O_GTE"; break; + case O_EQ: out << "O_EQ"; break; + case O_LT: out << "O_LT"; break; + case O_LTE: out << "O_LTE"; break; + case O_GT: out << "O_GT"; break; + case O_GTE: out << "O_GTE"; break; - case O_AND: out << "O_AND"; break; - case O_OR: out << "O_OR"; break; + case O_AND: out << "O_AND"; break; + case O_OR: out << "O_OR"; break; case O_QUERY: out << "O_QUERY"; break; - case O_COLON: out << "O_COLON"; break; + case O_COLON: out << "O_COLON"; break; - case O_CONS: out << "O_CONS"; break; - case O_SEQ: out << "O_SEQ"; break; + case O_CONS: out << "O_CONS"; break; + case O_SEQ: out << "O_SEQ"; break; case LAST: default: @@ -750,7 +750,7 @@ void expr_t::op_t::dump(std::ostream& out, const int depth) const if (left()) { left()->dump(out, depth + 1); if (kind > UNARY_OPERATORS && has_right()) - right()->dump(out, depth + 1); + right()->dump(out, depth + 1); } else if (kind > UNARY_OPERATORS) { assert(! has_right()); @@ -759,7 +759,7 @@ void expr_t::op_t::dump(std::ostream& out, const int depth) const } string op_context(const expr_t::ptr_op_t op, - const expr_t::ptr_op_t locus) + const expr_t::ptr_op_t locus) { ostream_pos_type start_pos, end_pos; expr_t::op_t::context_t context(op, locus, &start_pos, &end_pos); @@ -769,9 +769,9 @@ string op_context(const expr_t::ptr_op_t op, buf << "\n"; for (int i = 0; i <= end_pos; i++) { if (i > start_pos) - buf << "^"; + buf << "^"; else - buf << " "; + buf << " "; } } return buf.str(); @@ -56,13 +56,13 @@ public: private: mutable short refc; - ptr_op_t left_; + ptr_op_t left_; - variant<ptr_op_t, // used by all binary operators - value_t, // used by constant VALUE - string, // used by constant IDENT - expr_t::func_t // used by terminal FUNCTION - > data; + variant<ptr_op_t, // used by all binary operators + value_t, // used by constant VALUE + string, // used by constant IDENT + expr_t::func_t // used by terminal FUNCTION + > data; public: enum kind_t { @@ -225,13 +225,13 @@ public: private: void acquire() const { DEBUG("op.memory", - "Acquiring " << this << ", refc now " << refc + 1); + "Acquiring " << this << ", refc now " << refc + 1); assert(refc >= 0); refc++; } void release() const { DEBUG("op.memory", - "Releasing " << this << ", refc now " << refc - 1); + "Releasing " << this << ", refc now " << refc - 1); assert(refc > 0); if (--refc == 0) checked_delete(this); @@ -253,28 +253,28 @@ private: public: static ptr_op_t new_node(kind_t _kind, ptr_op_t _left = NULL, - ptr_op_t _right = NULL); + ptr_op_t _right = NULL); ptr_op_t compile(scope_t& scope, const int depth = 0); value_t calc(scope_t& scope, ptr_op_t * locus = NULL, - const int depth = 0); + const int depth = 0); struct context_t { - ptr_op_t expr_op; - ptr_op_t op_to_find; + ptr_op_t expr_op; + ptr_op_t op_to_find; ostream_pos_type * start_pos; ostream_pos_type * end_pos; - bool relaxed; + bool relaxed; context_t(const ptr_op_t& _expr_op = NULL, - const ptr_op_t& _op_to_find = NULL, - ostream_pos_type * const _start_pos = NULL, - ostream_pos_type * const _end_pos = NULL, - const bool _relaxed = true) + const ptr_op_t& _op_to_find = NULL, + ostream_pos_type * const _start_pos = NULL, + ostream_pos_type * const _end_pos = NULL, + const bool _relaxed = true) : expr_op(_expr_op), op_to_find(_op_to_find), - start_pos(_start_pos), end_pos(_end_pos), - relaxed(_relaxed) {} + start_pos(_start_pos), end_pos(_end_pos), + relaxed(_relaxed) {} }; bool print(std::ostream& out, const context_t& context = context_t()) const; @@ -300,8 +300,8 @@ private: ar & temp_op; } if (Archive::is_loading::value || kind == VALUE || kind == IDENT || - (kind > UNARY_OPERATORS && - (! has_right() || ! right()->is_function()))) { + (kind > UNARY_OPERATORS && + (! has_right() || ! right()->is_function()))) { ar & data; } else { variant<ptr_op_t, value_t, string, expr_t::func_t> temp_data; @@ -337,7 +337,7 @@ expr_t::op_t::wrap_functor(const expr_t::func_t& fobj) { #define WRAP_FUNCTOR(x) expr_t::op_t::wrap_functor(x) string op_context(const expr_t::ptr_op_t op, - const expr_t::ptr_op_t locus = NULL); + const expr_t::ptr_op_t locus = NULL); } // namespace ledger diff --git a/src/option.cc b/src/option.cc index b375dd8d..16f7713d 100644 --- a/src/option.cc +++ b/src/option.cc @@ -44,9 +44,9 @@ namespace { char * p = buf; foreach (char ch, name) { if (ch == '-') - *p++ = '_'; + *p++ = '_'; else - *p++ = ch; + *p++ = ch; } *p++ = '_'; *p = '\0'; @@ -75,30 +75,30 @@ namespace { } void process_option(const string& whence, const expr_t::func_t& opt, - scope_t& scope, const char * arg, const string& name) + scope_t& scope, const char * arg, const string& name) { try { call_scope_t args(scope); args.push_back(string_value(whence)); if (arg) - args.push_back(string_value(arg)); + args.push_back(string_value(arg)); opt(args); } catch (const std::exception& err) { if (name[0] == '-') - add_error_context(_("While parsing option '%1'") << name); - + add_error_context(_("While parsing option '%1'") << name); + else - add_error_context(_("While parsing environent variable '%1'") << name); + add_error_context(_("While parsing environent variable '%1'") << name); throw; } } } bool process_option(const string& whence, const string& name, scope_t& scope, - const char * arg, const string& varname) + const char * arg, const string& varname) { op_bool_tuple opt(find_option(scope, name)); if (opt.first) { @@ -109,9 +109,9 @@ bool process_option(const string& whence, const string& name, scope_t& scope, } void process_environment(const char ** envp, const string& tag, - scope_t& scope) + scope_t& scope) { - const char * tag_p = tag.c_str(); + const char * tag_p = tag.c_str(); string::size_type tag_len = tag.length(); assert(tag_p); @@ -123,25 +123,25 @@ void process_environment(const char ** envp, const string& tag, char * r = buf; const char * q; for (q = *p + tag_len; - *q && *q != '=' && r - buf < 8191; - q++) - if (*q == '_') - *r++ = '-'; - else - *r++ = static_cast<char>(std::tolower(*q)); + *q && *q != '=' && r - buf < 8191; + q++) + if (*q == '_') + *r++ = '-'; + else + *r++ = static_cast<char>(std::tolower(*q)); *r = '\0'; if (*q == '=') { - try { - string value = string(*p, q - *p); - if (! value.empty()) - process_option(string("$") + buf, string(buf), scope, q + 1, value); - } - catch (const std::exception& err) { - add_error_context(_("While parsing environment variable option '%1':") - << *p); - throw; - } + try { + string value = string(*p, q - *p); + if (! value.empty()) + process_option(string("$") + buf, string(buf), scope, q + 1, value); + } + catch (const std::exception& err) { + add_error_context(_("While parsing environment variable option '%1':") + << *p); + throw; + } } } } @@ -178,9 +178,9 @@ strings_list process_arguments(strings_list args, scope_t& scope) // --long-option or -s if ((*i)[1] == '-') { if ((*i)[2] == '\0') { - DEBUG("option.args", " it's a --, ending options processing"); - anywhere = false; - continue; + DEBUG("option.args", " it's a --, ending options processing"); + anywhere = false; + continue; } DEBUG("option.args", " it's an option string"); @@ -190,26 +190,26 @@ strings_list process_arguments(strings_list args, scope_t& scope) const char * value = NULL; if (const char * p = std::strchr(name, '=')) { - opt_name = string(name, p - name); - value = ++p; - DEBUG("option.args", " read option value from option: " << value); + opt_name = string(name, p - name); + value = ++p; + DEBUG("option.args", " read option value from option: " << value); } else { - opt_name = name; + opt_name = name; } op_bool_tuple opt(find_option(scope, opt_name)); if (! opt.first) - throw_(option_error, _("Illegal option --%1") << name); + throw_(option_error, _("Illegal option --%1") << name); if (opt.second && ! value && ++i != args.end() && value == NULL) { - value = (*i).c_str(); - DEBUG("option.args", " read option value from arg: " << value); - if (value == NULL) - throw_(option_error, _("Missing option argument for --%1") << name); + value = (*i).c_str(); + DEBUG("option.args", " read option value from arg: " << value); + if (value == NULL) + throw_(option_error, _("Missing option argument for --%1") << name); } process_option(string("--") + name, - opt.first->as_function(), scope, value, - string("--") + name); + opt.first->as_function(), scope, value, + string("--") + name); } else if ((*i)[1] == '\0') { throw_(option_error, _("illegal option -%1") << (*i)[0]); @@ -221,24 +221,24 @@ strings_list process_arguments(strings_list args, scope_t& scope) int x = 1; for (char c = (*i)[x]; c != '\0'; x++, c = (*i)[x]) { - op_bool_tuple opt(find_option(scope, c)); - if (! opt.first) - throw_(option_error, _("Illegal option -%1") << c); + op_bool_tuple opt(find_option(scope, c)); + if (! opt.first) + throw_(option_error, _("Illegal option -%1") << c); - option_queue.push_back(op_bool_char_tuple(opt.first, opt.second, c)); + option_queue.push_back(op_bool_char_tuple(opt.first, opt.second, c)); } foreach (op_bool_char_tuple& o, option_queue) { - const char * value = NULL; - if (o.truth && ++i != args.end()) { - value = (*i).c_str(); - DEBUG("option.args", " read option value from arg: " << value); - if (value == NULL) - throw_(option_error, - _("Missing option argument for -%1") << o.ch); - } - process_option(string("-") + o.ch, o.op->as_function(), scope, value, - string("-") + o.ch); + const char * value = NULL; + if (o.truth && ++i != args.end()) { + value = (*i).c_str(); + DEBUG("option.args", " read option value from arg: " << value); + if (value == NULL) + throw_(option_error, + _("Missing option argument for -%1") << o.ch); + } + process_option(string("-") + o.ch, o.op->as_function(), scope, value, + string("-") + o.ch); } } } diff --git a/src/option.h b/src/option.h index f11497a4..91ff26f9 100644 --- a/src/option.h +++ b/src/option.h @@ -52,10 +52,10 @@ template <typename T> class option_t { protected: - const char * name; + const char * name; string::size_type name_len; - const char ch; - bool handled; + const char ch; + bool handled; optional<string> source; option_t& operator=(const option_t&); @@ -63,7 +63,7 @@ protected: public: T * parent; value_t value; - bool wants_arg; + bool wants_arg; option_t(const char * _name, const char _ch = '\0') : name(_name), name_len(std::strlen(name)), ch(_ch), @@ -93,11 +93,11 @@ public: out.width(24); out << std::right << desc(); if (wants_arg) { - out << " = "; - value.print(out, 42); + out << " = "; + value.print(out, 42); } else { - out.width(45); - out << ' '; + out.width(45); + out << ' '; } out << std::left << *source << std::endl; } @@ -108,10 +108,10 @@ public: out << "--"; for (const char * p = name; *p; p++) { if (*p == '_') { - if (*(p + 1)) - out << '-'; + if (*(p + 1)) + out << '-'; } else { - out << *p; + out << *p; } } if (ch) @@ -145,7 +145,7 @@ public: on_with(whence, string_value(str)); } virtual void on_with(const optional<string>& whence, - const value_t& val) { + const value_t& val) { handled = true; value = val; source = whence; @@ -162,11 +162,11 @@ public: virtual void handler(call_scope_t& args) { if (wants_arg) { if (args.size() < 2) - throw_(std::runtime_error, _("No argument provided for %1") << desc()); + throw_(std::runtime_error, _("No argument provided for %1") << desc()); else if (args.size() > 2) - throw_(std::runtime_error, _("To many arguments provided for %1") << desc()); + throw_(std::runtime_error, _("To many arguments provided for %1") << desc()); else if (! args[0].is_string()) - throw_(std::runtime_error, _("Context argument for %1 not a string") << desc()); + throw_(std::runtime_error, _("Context argument for %1 not a string") << desc()); on_with(args[0].as_string(), args[1]); } else if (args.size() < 1) { @@ -194,9 +194,9 @@ public: } else if (wants_arg) { if (handled) - return value; + return value; else - return NULL_VALUE; + return NULL_VALUE; } else { return handled; @@ -204,13 +204,13 @@ public: } }; -#define BEGIN(type, name) \ +#define BEGIN(type, name) \ struct name ## option_t : public option_t<type> -#define CTOR(type, name) \ +#define CTOR(type, name) \ name ## option_t() : option_t<type>(#name) -#define DECL1(type, name, vartype, var, value) \ - vartype var ; \ +#define DECL1(type, name, vartype, var, value) \ + vartype var ; \ name ## option_t() : option_t<type>(#name), var(value) #define DO() virtual void handler_thunk(call_scope_t&) @@ -220,10 +220,10 @@ public: #define COPY_OPT(name, other) name ## handler(other.name ## handler) -#define MAKE_OPT_HANDLER(type, x) \ +#define MAKE_OPT_HANDLER(type, x) \ expr_t::op_t::wrap_functor(bind(&option_t<type>::handler_wrapper, x, _1)) -#define MAKE_OPT_FUNCTOR(type, x) \ +#define MAKE_OPT_FUNCTOR(type, x) \ expr_t::op_t::wrap_functor(bind(&option_t<type>::operator(), x, _1)) inline bool is_eq(const char * p, const char * n) { @@ -236,57 +236,57 @@ inline bool is_eq(const char * p, const char * n) { return *p == *n || (! *p && *n == '_' && ! *(n + 1)); } -#define OPT(name) \ - if (is_eq(p, #name)) \ +#define OPT(name) \ + if (is_eq(p, #name)) \ return ((name ## handler).parent = this, &(name ## handler)) -#define OPT_ALT(name, alt) \ - if (is_eq(p, #name) || is_eq(p, #alt)) \ +#define OPT_ALT(name, alt) \ + if (is_eq(p, #name) || is_eq(p, #alt)) \ return ((name ## handler).parent = this, &(name ## handler)) -#define OPT_(name) \ - if (! *(p + 1) || \ - ((name ## handler).wants_arg && \ - *(p + 1) == '_' && ! *(p + 2)) || \ - is_eq(p, #name)) \ +#define OPT_(name) \ + if (! *(p + 1) || \ + ((name ## handler).wants_arg && \ + *(p + 1) == '_' && ! *(p + 2)) || \ + is_eq(p, #name)) \ return ((name ## handler).parent = this, &(name ## handler)) -#define OPT_CH(name) \ - if (! *(p + 1) || \ - ((name ## handler).wants_arg && \ - *(p + 1) == '_' && ! *(p + 2))) \ +#define OPT_CH(name) \ + if (! *(p + 1) || \ + ((name ## handler).wants_arg && \ + *(p + 1) == '_' && ! *(p + 2))) \ return ((name ## handler).parent = this, &(name ## handler)) #define HANDLER(name) name ## handler #define HANDLED(name) HANDLER(name) -#define OPTION(type, name) \ - BEGIN(type, name) \ - { \ - CTOR(type, name) {} \ - } \ +#define OPTION(type, name) \ + BEGIN(type, name) \ + { \ + CTOR(type, name) {} \ + } \ END(name) -#define OPTION_(type, name, body) \ - BEGIN(type, name) \ - { \ - CTOR(type, name) {} \ - body \ - } \ +#define OPTION_(type, name, body) \ + BEGIN(type, name) \ + { \ + CTOR(type, name) {} \ + body \ + } \ END(name) -#define OPTION__(type, name, body) \ - BEGIN(type, name) \ - { \ - body \ - } \ +#define OPTION__(type, name, body) \ + BEGIN(type, name) \ + { \ + body \ + } \ END(name) bool process_option(const string& whence, const string& name, scope_t& scope, - const char * arg, const string& varname); + const char * arg, const string& varname); void process_environment(const char ** envp, const string& tag, - scope_t& scope); + scope_t& scope); strings_list process_arguments(strings_list args, scope_t& scope); diff --git a/src/output.cc b/src/output.cc index 5cef19bc..de0444cf 100644 --- a/src/output.cc +++ b/src/output.cc @@ -40,10 +40,10 @@ namespace ledger { -format_posts::format_posts(report_t& _report, - const string& format, - const optional<string>& _prepend_format, - std::size_t _prepend_width) +format_posts::format_posts(report_t& _report, + const string& format, + const optional<string>& _prepend_format, + std::size_t _prepend_width) : report(_report), prepend_width(_prepend_width), last_xact(NULL), last_post(NULL), first_report_title(true) { @@ -56,9 +56,9 @@ format_posts::format_posts(report_t& _report, const char * n = p + 2; if (const char * p = std::strstr(n, "%/")) { next_lines_format.parse_format(string(n, 0, p - n), - first_line_format); + first_line_format); between_format.parse_format(string(p + 2), - first_line_format); + first_line_format); } else { next_lines_format.parse_format(string(n), first_line_format); } @@ -86,16 +86,16 @@ void format_posts::operator()(post_t& post) if (! report_title.empty()) { if (first_report_title) - first_report_title = false; + first_report_title = false; else - out << '\n'; + out << '\n'; value_scope_t val_scope(string_value(report_title)); bind_scope_t inner_scope(bound_scope, val_scope); format_t group_title_format; group_title_format - .parse_format(report.HANDLER(group_title_format_).str()); + .parse_format(report.HANDLER(group_title_format_).str()); out << group_title_format(inner_scope); @@ -109,8 +109,8 @@ void format_posts::operator()(post_t& post) if (last_xact != post.xact) { if (last_xact) { - bind_scope_t xact_scope(report, *last_xact); - out << between_format(xact_scope); + bind_scope_t xact_scope(report, *last_xact); + out << between_format(xact_scope); } out << first_line_format(bound_scope); last_xact = post.xact; @@ -127,10 +127,10 @@ void format_posts::operator()(post_t& post) } } -format_accounts::format_accounts(report_t& _report, - const string& format, - const optional<string>& _prepend_format, - std::size_t _prepend_width) +format_accounts::format_accounts(report_t& _report, + const string& format, + const optional<string>& _prepend_format, + std::size_t _prepend_width) : report(_report), prepend_width(_prepend_width), disp_pred(), first_report_title(true) { @@ -172,16 +172,16 @@ std::size_t format_accounts::post_account(account_t& account, const bool flat) if (! report_title.empty()) { if (first_report_title) - first_report_title = false; + first_report_title = false; else - out << '\n'; + out << '\n'; value_scope_t val_scope(string_value(report_title)); bind_scope_t inner_scope(bound_scope, val_scope); format_t group_title_format; group_title_format - .parse_format(report.HANDLER(group_title_format_).str()); + .parse_format(report.HANDLER(group_title_format_).str()); out << group_title_format(inner_scope); @@ -203,7 +203,7 @@ std::size_t format_accounts::post_account(account_t& account, const bool flat) std::pair<std::size_t, std::size_t> format_accounts::mark_accounts(account_t& account, const bool flat) { - std::size_t visited = 0; + std::size_t visited = 0; std::size_t to_display = 0; foreach (accounts_map::value_type& pair, account.accounts) { @@ -218,7 +218,7 @@ format_accounts::mark_accounts(account_t& account, const bool flat) DEBUG("account.display", " it was visited itself"); DEBUG("account.display", " it has " << visited << " visited children"); DEBUG("account.display", - " it has " << to_display << " children to display"); + " it has " << to_display << " children to display"); #endif if (account.parent && @@ -226,10 +226,10 @@ format_accounts::mark_accounts(account_t& account, const bool flat) bind_scope_t bound_scope(report, account); call_scope_t call_scope(bound_scope); if ((! flat && to_display > 1) || - ((flat || to_display != 1 || - account.has_xflags(ACCOUNT_EXT_VISITED)) && - (report.HANDLED(empty) || report.fn_display_total(call_scope)) && - disp_pred(bound_scope))) { + ((flat || to_display != 1 || + account.has_xflags(ACCOUNT_EXT_VISITED)) && + (report.HANDLED(empty) || report.fn_display_total(call_scope)) && + disp_pred(bound_scope))) { account.xdata().add_flags(ACCOUNT_EXT_TO_DISPLAY); DEBUG("account.display", "Marking account as TO_DISPLAY"); to_display = 1; @@ -246,7 +246,7 @@ void format_accounts::flush() if (report.HANDLED(display_)) { DEBUG("account.display", - "Account display predicate: " << report.HANDLER(display_).str()); + "Account display predicate: " << report.HANDLER(display_).str()); disp_pred.parse(report.HANDLER(display_).str()); } @@ -265,7 +265,7 @@ void format_accounts::flush() if (prepend_format) { static_cast<std::ostream&>(report.output_stream).width(prepend_width); static_cast<std::ostream&>(report.output_stream) - << prepend_format(bound_scope); + << prepend_format(bound_scope); } out << total_line_format(bound_scope); @@ -346,12 +346,12 @@ void report_commodities::operator()(post_t& post) annotated_commodity_t& ann_comm(as_annotated_commodity(comm)); if (ann_comm.details.price) { std::map<commodity_t *, std::size_t>::iterator i = - commodities.find(&ann_comm.details.price->commodity()); + commodities.find(&ann_comm.details.price->commodity()); if (i == commodities.end()) - commodities.insert - (commodities_pair(&ann_comm.details.price->commodity(), 1)); + commodities.insert + (commodities_pair(&ann_comm.details.price->commodity(), 1)); else - (*i).second++; + (*i).second++; } } diff --git a/src/output.h b/src/output.h index a19c6235..ac3925c4 100644 --- a/src/output.h +++ b/src/output.h @@ -69,8 +69,8 @@ protected: public: format_posts(report_t& _report, const string& format, - const optional<string>& _prepend_format = none, - std::size_t _prepend_width = 0); + const optional<string>& _prepend_format = none, + std::size_t _prepend_width = 0); virtual ~format_posts() { TRACE_DTOR(format_posts); } @@ -83,8 +83,8 @@ public: virtual void operator()(post_t& post); virtual void clear() { - last_xact = NULL; - last_post = NULL; + last_xact = NULL; + last_post = NULL; report_title = ""; @@ -109,8 +109,8 @@ protected: public: format_accounts(report_t& _report, const string& _format, - const optional<string>& _prepend_format = none, - std::size_t _prepend_width = 0); + const optional<string>& _prepend_format = none, + std::size_t _prepend_width = 0); virtual ~format_accounts() { TRACE_DTOR(format_accounts); } @@ -123,7 +123,7 @@ public: } virtual std::size_t post_account(account_t& account, const bool flat); - virtual void flush(); + virtual void flush(); virtual void operator()(account_t& account); diff --git a/src/parser.cc b/src/parser.cc index f52949ce..db989f07 100644 --- a/src/parser.cc +++ b/src/parser.cc @@ -37,7 +37,7 @@ namespace ledger { expr_t::ptr_op_t expr_t::parser_t::parse_value_term(std::istream& in, - const parse_flags_t& tflags) const + const parse_flags_t& tflags) const { ptr_op_t node; @@ -60,16 +60,16 @@ expr_t::parser_t::parse_value_term(std::istream& in, if (tok.kind == token_t::LPAREN) { op_t::kind_t kind = op_t::O_CALL; if (ident == "any" || ident == "all") - kind = op_t::O_EXPAND; + kind = op_t::O_EXPAND; ptr_op_t call_node(new op_t(kind)); call_node->set_left(node); node = call_node; - push_token(tok); // let the parser see it again + push_token(tok); // let the parser see it again node->set_right(parse_value_expr(in, tflags.plus_flags(PARSE_SINGLE))); if (node->has_right() && node->right()->kind == op_t::O_CONS) - node->set_right(node->right()->left()); + node->set_right(node->right()->left()); } else { push_token(tok); } @@ -78,7 +78,7 @@ expr_t::parser_t::parse_value_term(std::istream& in, case token_t::LPAREN: node = parse_value_expr(in, tflags.plus_flags(PARSE_PARTIAL) - .minus_flags(PARSE_SINGLE)); + .minus_flags(PARSE_SINGLE)); tok = next_token(in, tflags, ')'); if (node->kind == op_t::O_CONS) { @@ -98,7 +98,7 @@ expr_t::parser_t::parse_value_term(std::istream& in, expr_t::ptr_op_t expr_t::parser_t::parse_dot_expr(std::istream& in, - const parse_flags_t& tflags) const + const parse_flags_t& tflags) const { ptr_op_t node(parse_value_term(in, tflags)); @@ -106,16 +106,16 @@ expr_t::parser_t::parse_dot_expr(std::istream& in, while (true) { token_t& tok = next_token(in, tflags.plus_flags(PARSE_OP_CONTEXT)); if (tok.kind == token_t::DOT) { - ptr_op_t prev(node); - node = new op_t(op_t::O_LOOKUP); - node->set_left(prev); - node->set_right(parse_value_term(in, tflags)); - if (! node->right()) - throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol); + ptr_op_t prev(node); + node = new op_t(op_t::O_LOOKUP); + node->set_left(prev); + node->set_right(parse_value_term(in, tflags)); + if (! node->right()) + throw_(parse_error, + _("%1 operator not followed by argument") << tok.symbol); } else { - push_token(tok); - break; + push_token(tok); + break; } } } @@ -125,7 +125,7 @@ expr_t::parser_t::parse_dot_expr(std::istream& in, expr_t::ptr_op_t expr_t::parser_t::parse_unary_expr(std::istream& in, - const parse_flags_t& tflags) const + const parse_flags_t& tflags) const { ptr_op_t node; @@ -136,7 +136,7 @@ expr_t::parser_t::parse_unary_expr(std::istream& in, ptr_op_t term(parse_dot_expr(in, tflags)); if (! term) throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol); + _("%1 operator not followed by argument") << tok.symbol); // A very quick optimization if (term->kind == op_t::VALUE) { @@ -153,7 +153,7 @@ expr_t::parser_t::parse_unary_expr(std::istream& in, ptr_op_t term(parse_dot_expr(in, tflags)); if (! term) throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol); + _("%1 operator not followed by argument") << tok.symbol); // A very quick optimization if (term->kind == op_t::VALUE) { @@ -177,7 +177,7 @@ expr_t::parser_t::parse_unary_expr(std::istream& in, expr_t::ptr_op_t expr_t::parser_t::parse_mul_expr(std::istream& in, - const parse_flags_t& tflags) const + const parse_flags_t& tflags) const { ptr_op_t node(parse_unary_expr(in, tflags)); @@ -186,18 +186,18 @@ expr_t::parser_t::parse_mul_expr(std::istream& in, token_t& tok = next_token(in, tflags.plus_flags(PARSE_OP_CONTEXT)); if (tok.kind == token_t::STAR || tok.kind == token_t::SLASH || - tok.kind == token_t::KW_DIV) { - ptr_op_t prev(node); - node = new op_t(tok.kind == token_t::STAR ? - op_t::O_MUL : op_t::O_DIV); - node->set_left(prev); - node->set_right(parse_unary_expr(in, tflags)); - if (! node->right()) - throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol); + tok.kind == token_t::KW_DIV) { + ptr_op_t prev(node); + node = new op_t(tok.kind == token_t::STAR ? + op_t::O_MUL : op_t::O_DIV); + node->set_left(prev); + node->set_right(parse_unary_expr(in, tflags)); + if (! node->right()) + throw_(parse_error, + _("%1 operator not followed by argument") << tok.symbol); } else { - push_token(tok); - break; + push_token(tok); + break; } } } @@ -207,7 +207,7 @@ expr_t::parser_t::parse_mul_expr(std::istream& in, expr_t::ptr_op_t expr_t::parser_t::parse_add_expr(std::istream& in, - const parse_flags_t& tflags) const + const parse_flags_t& tflags) const { ptr_op_t node(parse_mul_expr(in, tflags)); @@ -216,18 +216,18 @@ expr_t::parser_t::parse_add_expr(std::istream& in, token_t& tok = next_token(in, tflags.plus_flags(PARSE_OP_CONTEXT)); if (tok.kind == token_t::PLUS || - tok.kind == token_t::MINUS) { - ptr_op_t prev(node); - node = new op_t(tok.kind == token_t::PLUS ? - op_t::O_ADD : op_t::O_SUB); - node->set_left(prev); - node->set_right(parse_mul_expr(in, tflags)); - if (! node->right()) - throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol); + tok.kind == token_t::MINUS) { + ptr_op_t prev(node); + node = new op_t(tok.kind == token_t::PLUS ? + op_t::O_ADD : op_t::O_SUB); + node->set_left(prev); + node->set_right(parse_mul_expr(in, tflags)); + if (! node->right()) + throw_(parse_error, + _("%1 operator not followed by argument") << tok.symbol); } else { - push_token(tok); - break; + push_token(tok); + break; } } } @@ -237,70 +237,70 @@ expr_t::parser_t::parse_add_expr(std::istream& in, expr_t::ptr_op_t expr_t::parser_t::parse_logic_expr(std::istream& in, - const parse_flags_t& tflags) const + const parse_flags_t& tflags) const { ptr_op_t node(parse_add_expr(in, tflags)); if (node && ! tflags.has_flags(PARSE_SINGLE)) { while (true) { - op_t::kind_t kind = op_t::LAST; + op_t::kind_t kind = op_t::LAST; parse_flags_t _flags = tflags; - token_t& tok = next_token(in, tflags.plus_flags(PARSE_OP_CONTEXT)); - bool negate = false; + token_t& tok = next_token(in, tflags.plus_flags(PARSE_OP_CONTEXT)); + bool negate = false; switch (tok.kind) { case token_t::DEFINE: - kind = op_t::O_DEFINE; - break; + kind = op_t::O_DEFINE; + break; case token_t::EQUAL: - if (tflags.has_flags(PARSE_NO_ASSIGN)) - tok.rewind(in); - else - kind = op_t::O_EQ; - break; + if (tflags.has_flags(PARSE_NO_ASSIGN)) + tok.rewind(in); + else + kind = op_t::O_EQ; + break; case token_t::NEQUAL: - kind = op_t::O_EQ; - negate = true; - break; + kind = op_t::O_EQ; + negate = true; + break; case token_t::MATCH: - kind = op_t::O_MATCH; - break; + kind = op_t::O_MATCH; + break; case token_t::NMATCH: - kind = op_t::O_MATCH; - negate = true; - break; + kind = op_t::O_MATCH; + negate = true; + break; case token_t::LESS: - kind = op_t::O_LT; - break; + kind = op_t::O_LT; + break; case token_t::LESSEQ: - kind = op_t::O_LTE; - break; + kind = op_t::O_LTE; + break; case token_t::GREATER: - kind = op_t::O_GT; - break; + kind = op_t::O_GT; + break; case token_t::GREATEREQ: - kind = op_t::O_GTE; - break; + kind = op_t::O_GTE; + break; default: - push_token(tok); - goto exit_loop; + push_token(tok); + goto exit_loop; } if (kind != op_t::LAST) { - ptr_op_t prev(node); - node = new op_t(kind); - node->set_left(prev); - node->set_right(parse_add_expr(in, _flags)); - - if (! node->right()) - throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol); - - if (negate) { - prev = node; - node = new op_t(op_t::O_NOT); - node->set_left(prev); - } + ptr_op_t prev(node); + node = new op_t(kind); + node->set_left(prev); + node->set_right(parse_add_expr(in, _flags)); + + if (! node->right()) + throw_(parse_error, + _("%1 operator not followed by argument") << tok.symbol); + + if (negate) { + prev = node; + node = new op_t(op_t::O_NOT); + node->set_left(prev); + } } } } @@ -311,7 +311,7 @@ expr_t::parser_t::parse_logic_expr(std::istream& in, expr_t::ptr_op_t expr_t::parser_t::parse_and_expr(std::istream& in, - const parse_flags_t& tflags) const + const parse_flags_t& tflags) const { ptr_op_t node(parse_logic_expr(in, tflags)); @@ -320,16 +320,16 @@ expr_t::parser_t::parse_and_expr(std::istream& in, token_t& tok = next_token(in, tflags.plus_flags(PARSE_OP_CONTEXT)); if (tok.kind == token_t::KW_AND) { - ptr_op_t prev(node); - node = new op_t(op_t::O_AND); - node->set_left(prev); - node->set_right(parse_logic_expr(in, tflags)); - if (! node->right()) - throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol); + ptr_op_t prev(node); + node = new op_t(op_t::O_AND); + node->set_left(prev); + node->set_right(parse_logic_expr(in, tflags)); + if (! node->right()) + throw_(parse_error, + _("%1 operator not followed by argument") << tok.symbol); } else { - push_token(tok); - break; + push_token(tok); + break; } } } @@ -338,7 +338,7 @@ expr_t::parser_t::parse_and_expr(std::istream& in, expr_t::ptr_op_t expr_t::parser_t::parse_or_expr(std::istream& in, - const parse_flags_t& tflags) const + const parse_flags_t& tflags) const { ptr_op_t node(parse_and_expr(in, tflags)); @@ -347,16 +347,16 @@ expr_t::parser_t::parse_or_expr(std::istream& in, token_t& tok = next_token(in, tflags.plus_flags(PARSE_OP_CONTEXT)); if (tok.kind == token_t::KW_OR) { - ptr_op_t prev(node); - node = new op_t(op_t::O_OR); - node->set_left(prev); - node->set_right(parse_and_expr(in, tflags)); - if (! node->right()) - throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol); + ptr_op_t prev(node); + node = new op_t(op_t::O_OR); + node->set_left(prev); + node->set_right(parse_and_expr(in, tflags)); + if (! node->right()) + throw_(parse_error, + _("%1 operator not followed by argument") << tok.symbol); } else { - push_token(tok); - break; + push_token(tok); + break; } } } @@ -365,7 +365,7 @@ expr_t::parser_t::parse_or_expr(std::istream& in, expr_t::ptr_op_t expr_t::parser_t::parse_querycolon_expr(std::istream& in, - const parse_flags_t& tflags) const + const parse_flags_t& tflags) const { ptr_op_t node(parse_or_expr(in, tflags)); @@ -378,8 +378,8 @@ expr_t::parser_t::parse_querycolon_expr(std::istream& in, node->set_left(prev); node->set_right(parse_or_expr(in, tflags)); if (! node->right()) - throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol); + throw_(parse_error, + _("%1 operator not followed by argument") << tok.symbol); next_token(in, tflags.plus_flags(PARSE_OP_CONTEXT), ':'); prev = node->right(); @@ -387,42 +387,42 @@ expr_t::parser_t::parse_querycolon_expr(std::istream& in, subnode->set_left(prev); subnode->set_right(parse_or_expr(in, tflags)); if (! subnode->right()) - throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol); + throw_(parse_error, + _("%1 operator not followed by argument") << tok.symbol); node->set_right(subnode); } else if (tok.kind == token_t::KW_IF) { ptr_op_t if_op(parse_or_expr(in, tflags)); if (! if_op) - throw_(parse_error, _("'if' keyword not followed by argument")); + throw_(parse_error, _("'if' keyword not followed by argument")); tok = next_token(in, tflags.plus_flags(PARSE_OP_CONTEXT)); if (tok.kind == token_t::KW_ELSE) { - ptr_op_t else_op(parse_or_expr(in, tflags)); - if (! else_op) - throw_(parse_error, _("'else' keyword not followed by argument")); + ptr_op_t else_op(parse_or_expr(in, tflags)); + if (! else_op) + throw_(parse_error, _("'else' keyword not followed by argument")); - ptr_op_t subnode = new op_t(op_t::O_COLON); - subnode->set_left(node); - subnode->set_right(else_op); + ptr_op_t subnode = new op_t(op_t::O_COLON); + subnode->set_left(node); + subnode->set_right(else_op); - node = new op_t(op_t::O_QUERY); - node->set_left(if_op); - node->set_right(subnode); + node = new op_t(op_t::O_QUERY); + node->set_left(if_op); + node->set_right(subnode); } else { - ptr_op_t null_node = new op_t(op_t::VALUE); - null_node->set_value(NULL_VALUE); + ptr_op_t null_node = new op_t(op_t::VALUE); + null_node->set_value(NULL_VALUE); - ptr_op_t subnode = new op_t(op_t::O_COLON); - subnode->set_left(node); - subnode->set_right(null_node); + ptr_op_t subnode = new op_t(op_t::O_COLON); + subnode->set_left(node); + subnode->set_right(null_node); - node = new op_t(op_t::O_QUERY); - node->set_left(if_op); - node->set_right(subnode); + node = new op_t(op_t::O_QUERY); + node->set_left(if_op); + node->set_right(subnode); - push_token(tok); + push_token(tok); } } else { @@ -434,7 +434,7 @@ expr_t::parser_t::parse_querycolon_expr(std::istream& in, expr_t::ptr_op_t expr_t::parser_t::parse_value_expr(std::istream& in, - const parse_flags_t& tflags) const + const parse_flags_t& tflags) const { ptr_op_t node(parse_querycolon_expr(in, tflags)); @@ -449,21 +449,21 @@ expr_t::parser_t::parse_value_expr(std::istream& in, node->set_left(prev); node->set_right(parse_value_expr(in, tflags)); if (! node->right()) - throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol); + throw_(parse_error, + _("%1 operator not followed by argument") << tok.symbol); tok = next_token(in, tflags.plus_flags(PARSE_OP_CONTEXT)); } if (tok.kind != token_t::TOK_EOF) { if (tflags.has_flags(PARSE_PARTIAL)) - push_token(tok); + push_token(tok); else - tok.unexpected(); + tok.unexpected(); } } else if (! tflags.has_flags(PARSE_PARTIAL) && - ! tflags.has_flags(PARSE_SINGLE)) { + ! tflags.has_flags(PARSE_SINGLE)) { throw_(parse_error, _("Failed to parse value expression")); } @@ -471,9 +471,9 @@ expr_t::parser_t::parse_value_expr(std::istream& in, } expr_t::ptr_op_t -expr_t::parser_t::parse(std::istream& in, - const parse_flags_t& flags, - const optional<string>& original_string) +expr_t::parser_t::parse(std::istream& in, + const parse_flags_t& flags, + const optional<string>& original_string) { try { ptr_op_t top_node = parse_value_expr(in, flags); @@ -492,11 +492,11 @@ expr_t::parser_t::parse(std::istream& in, std::streamoff end_pos = 0; if (in.good()) - end_pos = in.tellg(); + end_pos = in.tellg(); std::streamoff pos = end_pos; if (pos > 0) - pos -= lookahead.length; + pos -= lookahead.length; DEBUG("parser.error", "original_string = '" << *original_string << "'"); DEBUG("parser.error", " pos = " << pos); @@ -505,8 +505,8 @@ expr_t::parser_t::parse(std::istream& in, DEBUG("parser.error", " token length = " << lookahead.length); add_error_context(line_context(*original_string, - static_cast<string::size_type>(pos), - static_cast<string::size_type>(end_pos))); + static_cast<string::size_type>(pos), + static_cast<string::size_type>(end_pos))); } throw; } diff --git a/src/parser.h b/src/parser.h index 2693fc79..93ea994f 100644 --- a/src/parser.h +++ b/src/parser.h @@ -50,10 +50,10 @@ namespace ledger { class expr_t::parser_t : public noncopyable { mutable token_t lookahead; - mutable bool use_lookahead; + mutable bool use_lookahead; token_t& next_token(std::istream& in, const parse_flags_t& tflags, - const char expecting = '\0') const { + const char expecting = '\0') const { if (use_lookahead) use_lookahead = false; else @@ -76,25 +76,25 @@ class expr_t::parser_t : public noncopyable } ptr_op_t parse_value_term(std::istream& in, - const parse_flags_t& flags) const; + const parse_flags_t& flags) const; ptr_op_t parse_dot_expr(std::istream& in, - const parse_flags_t& flags) const; + const parse_flags_t& flags) const; ptr_op_t parse_unary_expr(std::istream& in, - const parse_flags_t& flags) const; + const parse_flags_t& flags) const; ptr_op_t parse_mul_expr(std::istream& in, - const parse_flags_t& flags) const; + const parse_flags_t& flags) const; ptr_op_t parse_add_expr(std::istream& in, - const parse_flags_t& flags) const; + const parse_flags_t& flags) const; ptr_op_t parse_logic_expr(std::istream& in, - const parse_flags_t& flags) const; + const parse_flags_t& flags) const; ptr_op_t parse_and_expr(std::istream& in, - const parse_flags_t& flags) const; + const parse_flags_t& flags) const; ptr_op_t parse_or_expr(std::istream& in, - const parse_flags_t& flags) const; + const parse_flags_t& flags) const; ptr_op_t parse_querycolon_expr(std::istream& in, - const parse_flags_t& flags) const; + const parse_flags_t& flags) const; ptr_op_t parse_value_expr(std::istream& in, - const parse_flags_t& flags) const; + const parse_flags_t& flags) const; public: parser_t() : use_lookahead(false) { @@ -104,9 +104,9 @@ public: TRACE_DTOR(parser_t); } - ptr_op_t parse(std::istream& in, - const parse_flags_t& flags = PARSE_DEFAULT, - const optional<string>& original_string = NULL); + ptr_op_t parse(std::istream& in, + const parse_flags_t& flags = PARSE_DEFAULT, + const optional<string>& original_string = NULL); }; } // namespace ledger diff --git a/src/pool.cc b/src/pool.cc index 5285be92..618a43c5 100644 --- a/src/pool.cc +++ b/src/pool.cc @@ -67,11 +67,11 @@ commodity_t * commodity_pool_t::create(const string& symbol) } DEBUG("pool.commodities", - "Creating commodity '" << commodity->symbol() << "'"); + "Creating commodity '" << commodity->symbol() << "'"); std::pair<commodities_map::iterator, bool> result = commodities.insert(commodities_map::value_type(commodity->mapping_key(), - commodity.get())); + commodity.get())); assert(result.second); return commodity.release(); @@ -111,7 +111,7 @@ commodity_pool_t::create(const string& symbol, const annotation_t& details) } string commodity_pool_t::make_qualified_name(const commodity_t& comm, - const annotation_t& details) + const annotation_t& details) { assert(details); @@ -125,7 +125,7 @@ string commodity_pool_t::make_qualified_name(const commodity_t& comm, #if defined(DEBUG_ON) if (comm.qualified_symbol) DEBUG("pool.commodities", "make_qualified_name for " - << *comm.qualified_symbol << std::endl << details); + << *comm.qualified_symbol << std::endl << details); #endif DEBUG("pool.commodities", "qualified_name is " << name.str()); @@ -154,7 +154,7 @@ commodity_pool_t::find(const string& symbol, const annotation_t& details) commodity_t * commodity_pool_t::find_or_create(const string& symbol, - const annotation_t& details) + const annotation_t& details) { commodity_t * comm = find_or_create(symbol); if (! comm) @@ -167,9 +167,9 @@ commodity_pool_t::find_or_create(const string& symbol, } commodity_t * -commodity_pool_t::create(commodity_t& comm, - const annotation_t& details, - const string& mapping_key) +commodity_pool_t::create(commodity_t& comm, + const annotation_t& details, + const string& mapping_key) { assert(comm); assert(details); @@ -182,8 +182,8 @@ commodity_pool_t::create(commodity_t& comm, assert(! commodity->qualified_symbol->empty()); DEBUG("pool.commodities", "Creating annotated commodity " - << "symbol " << commodity->symbol() - << " key " << mapping_key << std::endl << details); + << "symbol " << commodity->symbol() + << " key " << mapping_key << std::endl << details); // Add the fully annotated name to the map, so that this symbol may // quickly be found again. @@ -191,14 +191,14 @@ commodity_pool_t::create(commodity_t& comm, std::pair<commodities_map::iterator, bool> result = commodities.insert(commodities_map::value_type(mapping_key, - commodity.get())); + commodity.get())); assert(result.second); return commodity.release(); } -commodity_t * commodity_pool_t::find_or_create(commodity_t& comm, - const annotation_t& details) +commodity_t * commodity_pool_t::find_or_create(commodity_t& comm, + const annotation_t& details) { assert(comm); assert(details); @@ -213,12 +213,12 @@ commodity_t * commodity_pool_t::find_or_create(commodity_t& comm, return create(comm, details, name); } -void commodity_pool_t::exchange(commodity_t& commodity, - const amount_t& per_unit_cost, - const datetime_t& moment) +void commodity_pool_t::exchange(commodity_t& commodity, + const amount_t& per_unit_cost, + const datetime_t& moment) { DEBUG("commodity.prices.add", "exchanging commodity " << commodity - << " at per unit cost " << per_unit_cost << " on " << moment); + << " at per unit cost " << per_unit_cost << " on " << moment); commodity_t& base_commodity (commodity.annotated ? @@ -228,11 +228,11 @@ void commodity_pool_t::exchange(commodity_t& commodity, } cost_breakdown_t -commodity_pool_t::exchange(const amount_t& amount, - const amount_t& cost, - const bool is_per_unit, - const optional<datetime_t>& moment, - const optional<string>& tag) +commodity_pool_t::exchange(const amount_t& amount, + const amount_t& cost, + const bool is_per_unit, + const optional<datetime_t>& moment, + const optional<string>& tag) { DEBUG("commodity.prices.add", "exchange: " << amount << " for " << cost); DEBUG("commodity.prices.add", "exchange: is-per-unit = " << is_per_unit); @@ -261,7 +261,7 @@ commodity_pool_t::exchange(const amount_t& amount, breakdown.final_cost = ! is_per_unit ? cost : cost * amount.abs(); DEBUG("commodity.prices.add", - "exchange: final-cost = " << breakdown.final_cost); + "exchange: final-cost = " << breakdown.final_cost); if (current_annotation && current_annotation->price) breakdown.basis_cost @@ -270,10 +270,10 @@ commodity_pool_t::exchange(const amount_t& amount, breakdown.basis_cost = breakdown.final_cost; DEBUG("commodity.prices.add", - "exchange: basis-cost = " << breakdown.basis_cost); + "exchange: basis-cost = " << breakdown.basis_cost); annotation_t annotation(per_unit_cost, moment ? - moment->date() : optional<date_t>(), tag); + moment->date() : optional<date_t>(), tag); annotation.add_flags(ANNOTATION_PRICE_CALCULATED); if (moment) @@ -284,7 +284,7 @@ commodity_pool_t::exchange(const amount_t& amount, breakdown.amount = amount_t(amount, annotation); DEBUG("commodity.prices.add", - "exchange: amount = " << breakdown.amount); + "exchange: amount = " << breakdown.amount); return breakdown; } @@ -328,7 +328,7 @@ commodity_pool_t::parse_price_directive(char * line, bool do_not_add_price) DEBUG("commodity.download", "Looking up symbol: " << symbol); if (commodity_t * commodity = find_or_create(symbol)) { DEBUG("commodity.download", "Adding price for " << symbol << ": " - << point.when << " " << point.price); + << point.when << " " << point.price); if (! do_not_add_price) commodity->add_price(point.when, point.price, true); commodity->add_flags(COMMODITY_KNOWN); @@ -340,8 +340,8 @@ commodity_pool_t::parse_price_directive(char * line, bool do_not_add_price) commodity_t * commodity_pool_t::parse_price_expression(const std::string& str, - const bool add_prices, - const optional<datetime_t>& moment) + const bool add_prices, + const optional<datetime_t>& moment) { scoped_array<char> buf(new char[str.length() + 1]); @@ -354,9 +354,9 @@ commodity_pool_t::parse_price_expression(const std::string& str, if (commodity_t * commodity = find_or_create(trim_ws(buf.get()))) { if (price && add_prices) { for (char * p = std::strtok(price, ";"); - p; - p = std::strtok(NULL, ";")) { - commodity->add_price(moment ? *moment : CURRENT_TIME(), amount_t(p)); + p; + p = std::strtok(NULL, ";")) { + commodity->add_price(moment ? *moment : CURRENT_TIME(), amount_t(p)); } } return commodity; @@ -364,9 +364,9 @@ commodity_pool_t::parse_price_expression(const std::string& str, return NULL; } -void commodity_pool_t::print_pricemap(std::ostream& out, - const keep_details_t& keep, - const optional<datetime_t>& moment) +void commodity_pool_t::print_pricemap(std::ostream& out, + const keep_details_t& keep, + const optional<datetime_t>& moment) { typedef std::map<commodity_t *, commodity_t *> comm_map_t; @@ -391,44 +391,44 @@ void commodity_pool_t::print_pricemap(std::ostream& out, out << "\"" << comm->symbol() << "\";\n"; if (! comm->has_flags(COMMODITY_NOMARKET) && - (! commodity_pool_t::current_pool->default_commodity || - comm != commodity_pool_t::current_pool->default_commodity)) { + (! commodity_pool_t::current_pool->default_commodity || + comm != commodity_pool_t::current_pool->default_commodity)) { if (optional<commodity_t::varied_history_t&> vhist = - comm->varied_history()) { - foreach (const commodity_t::history_by_commodity_map::value_type& pair, - vhist->histories) { - datetime_t most_recent; - amount_t most_recent_amt; - foreach (const commodity_t::history_map::value_type& inner_pair, - pair.second.prices) { - if ((most_recent.is_not_a_date_time() || - inner_pair.first > most_recent) && - (! moment || inner_pair.first <= moment)) { - most_recent = inner_pair.first; - most_recent_amt = inner_pair.second; - } - } - - if (! most_recent.is_not_a_date_time()) { - out << " "; - if (commodity_t::symbol_needs_quotes(comm->symbol())) - out << comm->symbol(); - else - out << "\"" << comm->symbol() << "\""; - - out << " -> "; - - if (commodity_t::symbol_needs_quotes(pair.first->symbol())) - out << pair.first->symbol(); - else - out << "\"" << pair.first->symbol() << "\""; - - out << " [label=\"" - << most_recent_amt.number() << "\\n" - << format_date(most_recent.date(), FMT_WRITTEN) - << "\" fontcolor=\"#008e28\"];\n"; - } - } + comm->varied_history()) { + foreach (const commodity_t::history_by_commodity_map::value_type& pair, + vhist->histories) { + datetime_t most_recent; + amount_t most_recent_amt; + foreach (const commodity_t::history_map::value_type& inner_pair, + pair.second.prices) { + if ((most_recent.is_not_a_date_time() || + inner_pair.first > most_recent) && + (! moment || inner_pair.first <= moment)) { + most_recent = inner_pair.first; + most_recent_amt = inner_pair.second; + } + } + + if (! most_recent.is_not_a_date_time()) { + out << " "; + if (commodity_t::symbol_needs_quotes(comm->symbol())) + out << comm->symbol(); + else + out << "\"" << comm->symbol() << "\""; + + out << " -> "; + + if (commodity_t::symbol_needs_quotes(pair.first->symbol())) + out << pair.first->symbol(); + else + out << "\"" << pair.first->symbol() << "\""; + + out << " [label=\"" + << most_recent_amt.number() << "\\n" + << format_date(most_recent.date(), FMT_WRITTEN) + << "\" fontcolor=\"#008e28\"];\n"; + } + } } } } @@ -67,19 +67,19 @@ public: typedef std::map<string, commodity_t *> commodities_map; commodities_map commodities; - commodity_t * null_commodity; - commodity_t * default_commodity; + commodity_t * null_commodity; + commodity_t * default_commodity; - bool keep_base; // --base + bool keep_base; // --base optional<path> price_db; // --price-db= - long quote_leeway; // --leeway= - bool get_quotes; // --download + long quote_leeway; // --leeway= + bool get_quotes; // --download static shared_ptr<commodity_pool_t> current_pool; function<optional<price_point_t> - (commodity_t& commodity, const optional<commodity_t&>& in_terms_of)> + (commodity_t& commodity, const optional<commodity_t&>& in_terms_of)> get_commodity_quote; explicit commodity_pool_t(); @@ -91,7 +91,7 @@ public: } string make_qualified_name(const commodity_t& comm, - const annotation_t& details); + const annotation_t& details); commodity_t * create(const string& symbol); commodity_t * find(const string& name); @@ -100,26 +100,26 @@ public: commodity_t * create(const string& symbol, const annotation_t& details); commodity_t * find(const string& symbol, const annotation_t& details); commodity_t * find_or_create(const string& symbol, - const annotation_t& details); + const annotation_t& details); - commodity_t * create(commodity_t& comm, - const annotation_t& details, - const string& mapping_key); + commodity_t * create(commodity_t& comm, + const annotation_t& details, + const string& mapping_key); - commodity_t * find_or_create(commodity_t& comm, - const annotation_t& details); + commodity_t * find_or_create(commodity_t& comm, + const annotation_t& details); // Exchange one commodity for another, while recording the factored price. - void exchange(commodity_t& commodity, - const amount_t& per_unit_cost, - const datetime_t& moment); + void exchange(commodity_t& commodity, + const amount_t& per_unit_cost, + const datetime_t& moment); - cost_breakdown_t exchange(const amount_t& amount, - const amount_t& cost, - const bool is_per_unit = false, - const optional<datetime_t>& moment = none, - const optional<string>& tag = none); + cost_breakdown_t exchange(const amount_t& amount, + const amount_t& cost, + const bool is_per_unit = false, + const optional<datetime_t>& moment = none, + const optional<string>& tag = none); // Parse commodity prices from a textual representation @@ -128,14 +128,14 @@ public: commodity_t * parse_price_expression(const std::string& str, - const bool add_prices = true, - const optional<datetime_t>& moment = none); + const bool add_prices = true, + const optional<datetime_t>& moment = none); // Output the commodity price map for a given date as a DOT file - void print_pricemap(std::ostream& out, - const keep_details_t& keep, - const optional<datetime_t>& moment = none); + void print_pricemap(std::ostream& out, + const keep_details_t& keep, + const optional<datetime_t>& moment = none); #if defined(HAVE_BOOST_SERIALIZATION) private: diff --git a/src/post.cc b/src/post.cc index e182a731..fa8bab4f 100644 --- a/src/post.cc +++ b/src/post.cc @@ -50,7 +50,7 @@ bool post_t::has_tag(const string& tag) const } bool post_t::has_tag(const mask_t& tag_mask, - const optional<mask_t>& value_mask) const + const optional<mask_t>& value_mask) const { if (item_t::has_tag(tag_mask, value_mask)) return true; @@ -59,19 +59,19 @@ bool post_t::has_tag(const mask_t& tag_mask, return false; } -optional<string> post_t::get_tag(const string& tag) const +optional<value_t> post_t::get_tag(const string& tag) const { - if (optional<string> value = item_t::get_tag(tag)) + if (optional<value_t> value = item_t::get_tag(tag)) return value; if (xact) return xact->get_tag(tag); return none; } -optional<string> post_t::get_tag(const mask_t& tag_mask, - const optional<mask_t>& value_mask) const +optional<value_t> post_t::get_tag(const mask_t& tag_mask, + const optional<mask_t>& value_mask) const { - if (optional<string> value = item_t::get_tag(tag_mask, value_mask)) + if (optional<value_t> value = item_t::get_tag(tag_mask, value_mask)) return value; if (xact) return xact->get_tag(tag_mask, value_mask); @@ -197,20 +197,27 @@ namespace { return post.has_xdata() && post.xdata().has_flags(POST_EXT_DIRECT_AMT); } - value_t get_commodity(post_t& post) { - if (post.has_xdata() && - post.xdata().has_flags(POST_EXT_COMPOUND)) - return string_value(post.xdata().compound_value.to_amount() - .commodity().symbol()); - else - return string_value(post.amount.commodity().symbol()); + value_t get_commodity(call_scope_t& scope) + { + in_context_t<post_t> env(scope, "&v"); + if (env.has(0)) { + return string_value(env.value_at(0).to_amount().commodity().symbol()); + } else { + post_t& post(find_scope<post_t>(scope)); + if (post.has_xdata() && + post.xdata().has_flags(POST_EXT_COMPOUND)) + return string_value(post.xdata().compound_value.to_amount() + .commodity().symbol()); + else + return string_value(post.amount.commodity().symbol()); + } } value_t get_commodity_is_primary(post_t& post) { if (post.has_xdata() && - post.xdata().has_flags(POST_EXT_COMPOUND)) + post.xdata().has_flags(POST_EXT_COMPOUND)) return post.xdata().compound_value.to_amount() - .commodity().has_flags(COMMODITY_PRIMARY); + .commodity().has_flags(COMMODITY_PRIMARY); else return post.amount.commodity().has_flags(COMMODITY_PRIMARY); } @@ -223,7 +230,7 @@ namespace { if (post.cost) return *post.cost; else if (post.has_xdata() && - post.xdata().has_flags(POST_EXT_COMPOUND)) + post.xdata().has_flags(POST_EXT_COMPOUND)) return post.xdata().compound_value; else if (post.amount.is_null()) return 0L; @@ -255,37 +262,37 @@ namespace { if (env.has(0)) { if (env.value_at(0).is_long()) { - if (env.get<long>(0) > 2) - name = format_t::truncate(env->reported_account()->fullname(), - env.get<long>(0) - 2, - 2 /* account_abbrev_length */); - else - name = env->reported_account()->fullname(); + if (env.get<long>(0) > 2) + name = format_t::truncate(env->reported_account()->fullname(), + env.get<long>(0) - 2, + 2 /* account_abbrev_length */); + else + name = env->reported_account()->fullname(); } else { - account_t * account = NULL; - account_t * master = env->account; - while (master->parent) - master = master->parent; - - if (env.value_at(0).is_string()) { - name = env.get<string>(0); - account = master->find_account(name, false); - } - else if (env.value_at(0).is_mask()) { - name = env.get<mask_t>(0).str(); - account = master->find_account_re(name); - } - else { - throw_(std::runtime_error, - _("Expected string or mask for argument 1, but received %1") - << env.value_at(0).label()); - } - - if (! account) - throw_(std::runtime_error, - _("Could not find an account matching ") << env.value_at(0)); - else - return value_t(static_cast<scope_t *>(account)); + account_t * account = NULL; + account_t * master = env->account; + while (master->parent) + master = master->parent; + + if (env.value_at(0).is_string()) { + name = env.get<string>(0); + account = master->find_account(name, false); + } + else if (env.value_at(0).is_mask()) { + name = env.get<mask_t>(0).str(); + account = master->find_account_re(name); + } + else { + throw_(std::runtime_error, + _("Expected string or mask for argument 1, but received %1") + << env.value_at(0).label()); + } + + if (! account) + throw_(std::runtime_error, + _("Could not find an account matching ") << env.value_at(0)); + else + return value_t(static_cast<scope_t *>(account)); } } else { name = env->reported_account()->fullname(); @@ -300,10 +307,10 @@ namespace { value_t acct = account_name(scope); if (acct.is_string()) { if (env->has_flags(POST_VIRTUAL)) { - if (env->must_balance()) - acct = string_value(string("[") + acct.as_string() + "]"); - else - acct = string_value(string("(") + acct.as_string() + ")"); + if (env->must_balance()) + acct = string_value(string("[") + acct.as_string() + "]"); + else + acct = string_value(string("(") + acct.as_string() + ")"); } } return acct; @@ -330,7 +337,7 @@ namespace { if (post.has_xdata()) { post_t::xdata_t& xdata(post.xdata()); if (! xdata.value_date.is_not_a_date()) - return xdata.value_date; + return xdata.value_date; } return post.date(); } @@ -353,13 +360,13 @@ namespace { foreach (post_t * p, post.xact->posts) { bind_scope_t bound_scope(scope, *p); if (p == &post && args.has(1) && - ! args.get<expr_t&>(1).calc(bound_scope).to_boolean()) { - // If the user specifies any(EXPR, false), and the context is a - // posting, then that posting isn't considered by the test. - ; // skip it + ! args.get<expr_t&>(1).calc(bound_scope).to_boolean()) { + // If the user specifies any(EXPR, false), and the context is a + // posting, then that posting isn't considered by the test. + ; // skip it } else if (expr.calc(bound_scope).to_boolean()) { - return true; + return true; } } return false; @@ -375,13 +382,13 @@ namespace { foreach (post_t * p, post.xact->posts) { bind_scope_t bound_scope(scope, *p); if (p == &post && args.has(1) && - ! args.get<expr_t&>(1).calc(bound_scope).to_boolean()) { - // If the user specifies any(EXPR, false), and the context is a - // posting, then that posting isn't considered by the test. - ; // skip it + ! args.get<expr_t&>(1).calc(bound_scope).to_boolean()) { + // If the user specifies any(EXPR, false), and the context is a + // posting, then that posting isn't considered by the test. + ; // skip it } else if (! expr.calc(bound_scope).to_boolean()) { - return false; + return false; } } return true; @@ -389,7 +396,7 @@ namespace { } expr_t::ptr_op_t post_t::lookup(const symbol_t::kind_t kind, - const string& name) + const string& name) { if (kind != symbol_t::FUNCTION) return item_t::lookup(kind, name); @@ -427,7 +434,7 @@ expr_t::ptr_op_t post_t::lookup(const symbol_t::kind_t kind, else if (name == "calculated") return WRAP_FUNCTOR(get_wrapper<&get_is_calculated>); else if (name == "commodity") - return WRAP_FUNCTOR(get_wrapper<&get_commodity>); + return WRAP_FUNCTOR(&get_commodity); break; case 'd': @@ -533,7 +540,7 @@ amount_t post_t::resolve_expr(scope_t& scope, expr_t& expr) } else { if (! result.is_amount()) throw_(amount_error, - _("Amount expressions must result in a simple amount")); + _("Amount expressions must result in a simple amount")); return result.as_amount(); } } @@ -571,7 +578,7 @@ bool post_t::valid() const posts_list::const_iterator i = std::find(xact->posts.begin(), - xact->posts.end(), this); + xact->posts.end(), this); if (i == xact->posts.end()) { DEBUG("ledger.validate", "post_t: ! found"); return false; @@ -608,7 +615,7 @@ void post_t::add_to_value(value_t& value, const optional<expr_t&>& expr) const } else if (expr) { bind_scope_t bound_scope(*expr->get_context(), - const_cast<post_t&>(*this)); + const_cast<post_t&>(*this)); #if 1 value_t temp(expr->calc(bound_scope)); add_or_set_value(value, temp); @@ -621,7 +628,7 @@ void post_t::add_to_value(value_t& value, const optional<expr_t&>& expr) const #endif } else if (xdata_ && xdata_->has_flags(POST_EXT_VISITED) && - ! xdata_->visited_value.is_null()) { + ! xdata_->visited_value.is_null()) { add_or_set_value(value, xdata_->visited_value); } else { @@ -708,18 +715,18 @@ void to_xml(std::ostream& out, const post_t& post) push_xml y(out, "metadata"); foreach (const item_t::string_map::value_type& pair, *post.metadata) { if (pair.second.first) { - push_xml z(out, "variable"); - { - push_xml z(out, "key"); - out << y.guard(pair.first); - } - { - push_xml z(out, "value"); - out << y.guard(*pair.second.first); - } + push_xml z(out, "variable"); + { + push_xml z(out, "key"); + out << y.guard(pair.first); + } + { + push_xml z(out, "value"); + to_xml(out, *pair.second.first); + } } else { - push_xml z(out, "tag"); - out << y.guard(pair.first); + push_xml z(out, "tag"); + out << y.guard(pair.first); } } } @@ -52,32 +52,33 @@ class account_t; class post_t : public item_t { public: -#define POST_VIRTUAL 0x04 // the account was specified with (parens) -#define POST_MUST_BALANCE 0x08 // posting must balance in the transaction -#define POST_CALCULATED 0x10 // posting's amount was calculated -#define POST_COST_CALCULATED 0x20 // posting's cost was calculated -#define POST_COST_IN_FULL 0x40 // cost specified using @@ -#define POST_ANONYMIZED 0x80 // a temporary, anonymous posting - - xact_t * xact; // only set for posts of regular xacts - account_t * account; - - amount_t amount; // can be null until finalization +#define POST_VIRTUAL 0x0010 // the account was specified with (parens) +#define POST_MUST_BALANCE 0x0020 // posting must balance in the transaction +#define POST_CALCULATED 0x0040 // posting's amount was calculated +#define POST_COST_CALCULATED 0x0080 // posting's cost was calculated +#define POST_COST_IN_FULL 0x0100 // cost specified using @@ +#define POST_COST_FIXATED 0x0200 // cost is fixed using = indicator +#define POST_ANONYMIZED 0x0400 // a temporary, anonymous posting + + xact_t * xact; // only set for posts of regular xacts + account_t * account; + + amount_t amount; // can be null until finalization optional<expr_t> amount_expr; optional<amount_t> cost; optional<amount_t> assigned_amount; post_t(account_t * _account = NULL, - flags_t _flags = ITEM_NORMAL) + flags_t _flags = ITEM_NORMAL) : item_t(_flags), xact(NULL), account(_account) { TRACE_CTOR(post_t, "account_t *, flags_t"); } - post_t(account_t * _account, - const amount_t& _amount, - flags_t _flags = ITEM_NORMAL, - const optional<string>& _note = none) + post_t(account_t * _account, + const amount_t& _amount, + flags_t _flags = ITEM_NORMAL, + const optional<string>& _note = none) : item_t(_flags, _note), xact(NULL), account(_account), amount(_amount) { @@ -100,11 +101,11 @@ public: virtual bool has_tag(const string& tag) const; virtual bool has_tag(const mask_t& tag_mask, - const optional<mask_t>& value_mask = none) const; + const optional<mask_t>& value_mask = none) const; - virtual optional<string> get_tag(const string& tag) const; - virtual optional<string> get_tag(const mask_t& tag_mask, - const optional<mask_t>& value_mask = none) const; + virtual optional<value_t> get_tag(const string& tag) const; + virtual optional<value_t> get_tag(const mask_t& tag_mask, + const optional<mask_t>& value_mask = none) const; virtual date_t value_date() const; virtual date_t date() const; @@ -116,7 +117,7 @@ public: } virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name); + const string& name); amount_t resolve_expr(scope_t& scope, expr_t& expr); @@ -137,14 +138,14 @@ public: #define POST_EXT_MATCHES 0x0080 #define POST_EXT_CONSIDERED 0x0100 - value_t visited_value; - value_t compound_value; - value_t total; - std::size_t count; - date_t date; - date_t value_date; - datetime_t datetime; - account_t * account; + value_t visited_value; + value_t compound_value; + value_t total; + std::size_t count; + date_t date; + date_t value_date; + datetime_t datetime; + account_t * account; std::list<sort_value_t> sort_values; @@ -154,13 +155,13 @@ public: } xdata_t(const xdata_t& other) : supports_flags<uint_least16_t>(other.flags()), - visited_value(other.visited_value), - compound_value(other.compound_value), - total(other.total), - count(other.count), - date(other.date), - account(other.account), - sort_values(other.sort_values) + visited_value(other.visited_value), + compound_value(other.compound_value), + total(other.total), + count(other.count), + date(other.date), + account(other.account), + sort_values(other.sort_values) { TRACE_CTOR(post_t::xdata_t, "copy"); } @@ -191,14 +192,14 @@ public: } void add_to_value(value_t& value, - const optional<expr_t&>& expr = none) const; + const optional<expr_t&>& expr = none) const; void set_reported_account(account_t * account); account_t * reported_account() { if (xdata_) if (account_t * acct = xdata_->account) - return acct; + return acct; return account; } @@ -212,12 +213,12 @@ public: { bool operator()(const post_t * left, const post_t * right) const { gregorian::date_duration duration = - left->actual_date() - right->actual_date(); + left->actual_date() - right->actual_date(); if (duration.days() == 0) { - return ((left->pos ? left->pos->sequence : 0) < - (right->pos ? right->pos->sequence : 0)); + return ((left->pos ? left->pos->sequence : 0) < + (right->pos ? right->pos->sequence : 0)); } else { - return duration.days() < 0; + return duration.days() < 0; } } }; diff --git a/src/precmd.cc b/src/precmd.cc index e545a783..f78d766e 100644 --- a/src/precmd.cc +++ b/src/precmd.cc @@ -48,27 +48,28 @@ namespace { { string str; { - std::ostringstream buf; - - buf << "2004/05/27 Book Store\n" - << " ; This note applies to all postings. :SecondTag:\n" - << " Expenses:Books 20 BOOK @ $10\n" - << " ; Metadata: Some Value\n" - << " ; :ExampleTag:\n" - << " ; Here follows a note describing the posting.\n" - << " Liabilities:MasterCard $-200.00\n"; - - str = buf.str(); + std::ostringstream buf; + + buf << "2004/05/27 Book Store\n" + << " ; This note applies to all postings. :SecondTag:\n" + << " Expenses:Books 20 BOOK @ $10\n" + << " ; Metadata: Some Value\n" + << " ; Typed:: $100 + $200\n" + << " ; :ExampleTag:\n" + << " ; Here follows a note describing the posting.\n" + << " Liabilities:MasterCard $-200.00\n"; + + str = buf.str(); } std::ostream& out(report.output_stream); out << _("--- Context is first posting of the following transaction ---") - << std::endl << str << std::endl; + << std::endl << str << std::endl; { - std::istringstream in(str); - report.session.journal->parse(in, report.session); - report.session.journal->clear_xdata(); + std::istringstream in(str); + report.session.journal->parse(in, report.session); + report.session.journal->clear_xdata(); } } xact_t * first = report.session.journal->xacts.front(); @@ -193,7 +194,7 @@ value_t query_command(call_scope_t& args) if (query.tokens_remaining()) { out << std::endl << _("====== Display predicate ======") - << std::endl << std::endl; + << std::endl << std::endl; query.parse_again(); diff --git a/src/predicate.h b/src/predicate.h index c21167d7..fc99c3c6 100644 --- a/src/predicate.h +++ b/src/predicate.h @@ -66,12 +66,12 @@ public: predicate_t(const query_t& other); predicate_t(const string& str, const keep_details_t& _what_to_keep, - const parse_flags_t& flags = PARSE_DEFAULT) + const parse_flags_t& flags = PARSE_DEFAULT) : expr_t(str, flags), what_to_keep(_what_to_keep) { TRACE_CTOR(predicate_t, "string, keep_details_t, parse_flags_t"); } predicate_t(std::istream& in, const keep_details_t& _what_to_keep, - const parse_flags_t& flags = PARSE_DEFAULT) + const parse_flags_t& flags = PARSE_DEFAULT) : expr_t(in, flags), what_to_keep(_what_to_keep) { TRACE_CTOR(predicate_t, "std::istream&, keep_details_t, parse_flags_t"); } @@ -81,10 +81,10 @@ public: virtual value_t real_calc(scope_t& scope) { return (*this ? - expr_t::real_calc(scope) - .strip_annotations(what_to_keep) - .to_boolean() : - true); + expr_t::real_calc(scope) + .strip_annotations(what_to_keep) + .to_boolean() : + true); } #if defined(HAVE_BOOST_SERIALIZATION) diff --git a/src/print.cc b/src/print.cc index 84aa441f..de35a31d 100644 --- a/src/print.cc +++ b/src/print.cc @@ -41,10 +41,10 @@ namespace ledger { namespace { - void print_note(std::ostream& out, - const string& note, - const std::size_t columns, - const std::size_t prior_width) + void print_note(std::ostream& out, + const string& note, + const std::size_t columns, + const std::size_t prior_width) { // The 4 is for four leading spaces at the beginning of the posting, and // the 3 is for two spaces and a semi-colon before the note. @@ -56,20 +56,20 @@ namespace { bool need_separator = false; for (const char * p = note.c_str(); *p; p++) { if (*p == '\n') { - need_separator = true; + need_separator = true; } else { - if (need_separator) { - out << "\n ;"; - need_separator = false; - } - out << *p; + if (need_separator) { + out << "\n ;"; + need_separator = false; + } + out << *p; } } } void print_xact(report_t& report, std::ostream& out, xact_t& xact) { - format_type_t format_type = FMT_WRITTEN; + format_type_t format_type = FMT_WRITTEN; optional<const char *> format; if (report.HANDLED(date_format_)) { @@ -80,15 +80,15 @@ namespace { std::ostringstream buf; buf << format_date(item_t::use_effective_date ? - xact.date() : xact.actual_date(), - format_type, format); + xact.date() : xact.actual_date(), + format_type, format); if (! item_t::use_effective_date && xact.effective_date()) buf << '=' << format_date(*xact.effective_date(), - format_type, format); + format_type, format); buf << ' '; buf << (xact.state() == item_t::CLEARED ? "* " : - (xact.state() == item_t::PENDING ? "! " : "")); + (xact.state() == item_t::PENDING ? "! " : "")); if (xact.code) buf << '(' << *xact.code << ") "; @@ -99,7 +99,7 @@ namespace { out << leader; std::size_t columns = (report.HANDLED(columns_) ? - report.HANDLER(columns_).value.to_long() : 80); + report.HANDLER(columns_).value.to_long() : 80); if (xact.note) print_note(out, *xact.note, columns, unistring(leader).length()); @@ -107,112 +107,112 @@ namespace { if (xact.metadata) { foreach (const item_t::string_map::value_type& data, *xact.metadata) { - if (! data.second.second) { - out << " ; "; - if (data.second.first) - out << data.first << ": " << *data.second.first; - else - out << ':' << data.first << ":"; - out << '\n'; - } + if (! data.second.second) { + out << " ; "; + if (data.second.first) + out << data.first << ": " << *data.second.first; + else + out << ':' << data.first << ":"; + out << '\n'; + } } } foreach (post_t * post, xact.posts) { - if (post->has_flags(ITEM_TEMP | ITEM_GENERATED) && - ! post->has_flags(POST_ANONYMIZED) && - ! report.HANDLED(print_virtual)) - continue; + if (! report.HANDLED(generated) && + (post->has_flags(ITEM_TEMP | ITEM_GENERATED) && + ! post->has_flags(POST_ANONYMIZED))) + continue; out << " "; std::ostringstream buf; if (xact.state() == item_t::UNCLEARED) - buf << (post->state() == item_t::CLEARED ? "* " : - (post->state() == item_t::PENDING ? "! " : "")); + buf << (post->state() == item_t::CLEARED ? "* " : + (post->state() == item_t::PENDING ? "! " : "")); if (post->has_flags(POST_VIRTUAL)) { - if (post->has_flags(POST_MUST_BALANCE)) - buf << '['; - else - buf << '('; + if (post->has_flags(POST_MUST_BALANCE)) + buf << '['; + else + buf << '('; } buf << post->account->fullname(); if (post->has_flags(POST_VIRTUAL)) { - if (post->has_flags(POST_MUST_BALANCE)) - buf << ']'; - else - buf << ')'; + if (post->has_flags(POST_MUST_BALANCE)) + buf << ']'; + else + buf << ')'; } unistring name(buf.str()); std::size_t account_width = - (report.HANDLER(account_width_).specified ? - report.HANDLER(account_width_).value.to_long() : 36); + (report.HANDLER(account_width_).specified ? + report.HANDLER(account_width_).value.to_long() : 36); if (account_width < name.length()) - account_width = name.length(); - - if (! post->has_flags(POST_CALCULATED) || report.HANDLED(print_virtual)) { - out << name.extract(); - int slip = (static_cast<int>(account_width) - - static_cast<int>(name.length())); - if (slip > 0) { - out.width(slip); - out << ' '; - } - - std::ostringstream amtbuf; - - string amt; - if (post->amount_expr) { - amt = post->amount_expr->text(); - } else { - int amount_width = - (report.HANDLER(amount_width_).specified ? - report.HANDLER(amount_width_).value.to_int() : 12); - - std::ostringstream amt_str; - value_t(post->amount).print(amt_str, amount_width, -1, - AMOUNT_PRINT_RIGHT_JUSTIFY | - AMOUNT_PRINT_NO_COMPUTED_ANNOTATIONS); - amt = amt_str.str(); - } - - string trimmed_amt(amt); - trim_left(trimmed_amt); - int amt_slip = (static_cast<int>(amt.length()) - - static_cast<int>(trimmed_amt.length())); - if (slip + amt_slip < 2) - amtbuf << string(2 - (slip + amt_slip), ' '); - amtbuf << amt; - - if (post->cost && - ! post->has_flags(POST_CALCULATED | POST_COST_CALCULATED)) { - if (post->has_flags(POST_COST_IN_FULL)) - amtbuf << " @@ " << post->cost->abs(); - else - amtbuf << " @ " - << (*post->cost / post->amount).abs(); - } - - if (post->assigned_amount) - amtbuf << " = " << post->assigned_amount; - - string trailer = amtbuf.str(); - out << trailer; - - account_width += unistring(trailer).length(); + account_width = name.length(); + + if (! post->has_flags(POST_CALCULATED) || report.HANDLED(generated)) { + out << name.extract(); + int slip = (static_cast<int>(account_width) - + static_cast<int>(name.length())); + if (slip > 0) { + out.width(slip); + out << ' '; + } + + std::ostringstream amtbuf; + + string amt; + if (post->amount_expr) { + amt = post->amount_expr->text(); + } else { + int amount_width = + (report.HANDLER(amount_width_).specified ? + report.HANDLER(amount_width_).value.to_int() : 12); + + std::ostringstream amt_str; + value_t(post->amount).print(amt_str, amount_width, -1, + AMOUNT_PRINT_RIGHT_JUSTIFY | + AMOUNT_PRINT_NO_COMPUTED_ANNOTATIONS); + amt = amt_str.str(); + } + + string trimmed_amt(amt); + trim_left(trimmed_amt); + int amt_slip = (static_cast<int>(amt.length()) - + static_cast<int>(trimmed_amt.length())); + if (slip + amt_slip < 2) + amtbuf << string(2 - (slip + amt_slip), ' '); + amtbuf << amt; + + if (post->cost && + ! post->has_flags(POST_CALCULATED | POST_COST_CALCULATED)) { + if (post->has_flags(POST_COST_IN_FULL)) + amtbuf << " @@ " << post->cost->abs(); + else + amtbuf << " @ " + << (*post->cost / post->amount).abs(); + } + + if (post->assigned_amount) + amtbuf << " = " << post->assigned_amount; + + string trailer = amtbuf.str(); + out << trailer; + + account_width += unistring(trailer).length(); } else { - out << buf.str(); + out << buf.str(); } if (post->note) - print_note(out, *post->note, columns, 4 + account_width); + print_note(out, *post->note, columns, 4 + account_width); out << '\n'; } } diff --git a/src/print.h b/src/print.h index f6ef0868..edfe864d 100644 --- a/src/print.h +++ b/src/print.h @@ -55,14 +55,14 @@ class report_t; class print_xacts : public item_handler<post_t> { protected: - typedef std::list<xact_t *> xacts_list; + typedef std::list<xact_t *> xacts_list; typedef std::map<xact_t *, bool> xacts_present_map; - report_t& report; + report_t& report; xacts_present_map xacts_present; - xacts_list xacts; - bool print_raw; - bool first_title; + xacts_list xacts; + bool print_raw; + bool first_title; public: print_xacts(report_t& _report, bool _print_raw = false) diff --git a/src/pstream.h b/src/pstream.h index bba2845e..5fac20bd 100644 --- a/src/pstream.h +++ b/src/pstream.h @@ -53,44 +53,44 @@ class ptristream : public std::istream ptrinbuf& operator=(const ptrinbuf&); protected: - char * ptr; + char * ptr; std::size_t len; public: ptrinbuf(char * _ptr, std::size_t _len) : ptr(_ptr), len(_len) { if (*ptr && len == 0) - len = std::strlen(ptr); + len = std::strlen(ptr); - setg(ptr, // beginning of putback area - ptr, // read position - ptr+len); // end position + setg(ptr, // beginning of putback area + ptr, // read position + ptr+len); // end position } protected: virtual int_type underflow() { // is read position before end of buffer? if (gptr() < egptr()) - return traits_type::to_int_type(*gptr()); + return traits_type::to_int_type(*gptr()); else - return EOF; + return EOF; } virtual pos_type seekoff(off_type off, ios_base::seekdir way, - ios_base::openmode) + ios_base::openmode) { switch (way) { case std::ios::cur: - setg(ptr, gptr()+off, ptr+len); - break; + setg(ptr, gptr()+off, ptr+len); + break; case std::ios::beg: - setg(ptr, ptr+off, ptr+len); - break; + setg(ptr, ptr+off, ptr+len); + break; case std::ios::end: - setg(ptr, egptr()+off, ptr+len); - break; + setg(ptr, egptr()+off, ptr+len); + break; default: - return pos_type(off_type(-1)); + return pos_type(off_type(-1)); } return pos_type(gptr() - ptr); } diff --git a/src/py_account.cc b/src/py_account.cc index 2b860a24..af51ffce 100644 --- a/src/py_account.cc +++ b/src/py_account.cc @@ -82,7 +82,7 @@ namespace { } account_t * py_find_account_2(journal_t& journal, const string& name, - const bool auto_create) + const bool auto_create) { return journal.find_account(name, auto_create); } @@ -99,14 +99,14 @@ namespace { void export_account() { - scope().attr("ACCOUNT_EXT_SORT_CALC") = ACCOUNT_EXT_SORT_CALC; + scope().attr("ACCOUNT_EXT_SORT_CALC") = ACCOUNT_EXT_SORT_CALC; scope().attr("ACCOUNT_EXT_HAS_NON_VIRTUALS") = ACCOUNT_EXT_HAS_NON_VIRTUALS; scope().attr("ACCOUNT_EXT_HAS_UNB_VIRTUALS") = ACCOUNT_EXT_HAS_UNB_VIRTUALS; scope().attr("ACCOUNT_EXT_AUTO_VIRTUALIZE") = ACCOUNT_EXT_AUTO_VIRTUALIZE; - scope().attr("ACCOUNT_EXT_VISITED") = ACCOUNT_EXT_VISITED; - scope().attr("ACCOUNT_EXT_MATCHING") = ACCOUNT_EXT_MATCHING; + scope().attr("ACCOUNT_EXT_VISITED") = ACCOUNT_EXT_VISITED; + scope().attr("ACCOUNT_EXT_MATCHING") = ACCOUNT_EXT_MATCHING; scope().attr("ACCOUNT_EXT_TO_DISPLAY") = ACCOUNT_EXT_TO_DISPLAY; - scope().attr("ACCOUNT_EXT_DISPLAYED") = ACCOUNT_EXT_DISPLAYED; + scope().attr("ACCOUNT_EXT_DISPLAYED") = ACCOUNT_EXT_DISPLAYED; class_< account_t::xdata_t::details_t > ("AccountXDataDetails") .def_readonly("total", &account_t::xdata_t::details_t::total) @@ -115,30 +115,30 @@ void export_account() .def_readonly("posts_count", &account_t::xdata_t::details_t::posts_count) .def_readonly("posts_virtuals_count", - &account_t::xdata_t::details_t::posts_virtuals_count) + &account_t::xdata_t::details_t::posts_virtuals_count) .def_readonly("posts_cleared_count", - &account_t::xdata_t::details_t::posts_cleared_count) + &account_t::xdata_t::details_t::posts_cleared_count) .def_readonly("posts_last_7_count", - &account_t::xdata_t::details_t::posts_last_7_count) + &account_t::xdata_t::details_t::posts_last_7_count) .def_readonly("posts_last_30_count", - &account_t::xdata_t::details_t::posts_last_30_count) + &account_t::xdata_t::details_t::posts_last_30_count) .def_readonly("posts_this_month_count", - &account_t::xdata_t::details_t::posts_this_month_count) + &account_t::xdata_t::details_t::posts_this_month_count) .def_readonly("earliest_post", - &account_t::xdata_t::details_t::earliest_post) + &account_t::xdata_t::details_t::earliest_post) .def_readonly("earliest_cleared_post", - &account_t::xdata_t::details_t::earliest_cleared_post) + &account_t::xdata_t::details_t::earliest_cleared_post) .def_readonly("latest_post", - &account_t::xdata_t::details_t::latest_post) + &account_t::xdata_t::details_t::latest_post) .def_readonly("latest_cleared_post", - &account_t::xdata_t::details_t::latest_cleared_post) + &account_t::xdata_t::details_t::latest_cleared_post) .def_readonly("filenames", &account_t::xdata_t::details_t::filenames) .def_readonly("accounts_referenced", - &account_t::xdata_t::details_t::accounts_referenced) + &account_t::xdata_t::details_t::accounts_referenced) .def_readonly("payees_referenced", - &account_t::xdata_t::details_t::payees_referenced) + &account_t::xdata_t::details_t::payees_referenced) .def(self += self) @@ -148,8 +148,8 @@ void export_account() class_< account_t::xdata_t > ("AccountXData") #if 1 .add_property("flags", - &supports_flags<uint_least16_t>::flags, - &supports_flags<uint_least16_t>::set_flags) + &supports_flags<uint_least16_t>::flags, + &supports_flags<uint_least16_t>::set_flags) .def("has_flags", &supports_flags<uint_least16_t>::has_flags) .def("clear_flags", &supports_flags<uint_least16_t>::clear_flags) .def("add_flags", &supports_flags<uint_least16_t>::add_flags) @@ -163,14 +163,14 @@ void export_account() ; scope().attr("ACCOUNT_NORMAL") = ACCOUNT_NORMAL; - scope().attr("ACCOUNT_KNOWN") = ACCOUNT_KNOWN; - scope().attr("ACCOUNT_TEMP") = ACCOUNT_TEMP; + scope().attr("ACCOUNT_KNOWN") = ACCOUNT_KNOWN; + scope().attr("ACCOUNT_TEMP") = ACCOUNT_TEMP; class_< account_t > ("Account") #if 1 .add_property("flags", - &supports_flags<>::flags, - &supports_flags<>::set_flags) + &supports_flags<>::flags, + &supports_flags<>::set_flags) .def("has_flags", &supports_flags<>::has_flags) .def("clear_flags", &supports_flags<>::clear_flags) .def("add_flags", &supports_flags<>::add_flags) @@ -178,8 +178,8 @@ void export_account() #endif .add_property("parent", - make_getter(&account_t::parent, - return_internal_reference<>())) + make_getter(&account_t::parent, + return_internal_reference<>())) .def_readwrite("name", &account_t::name) .def_readwrite("note", &account_t::note) @@ -195,9 +195,9 @@ void export_account() .def("remove_account", &account_t::remove_account) .def("find_account", &account_t::find_account, - return_internal_reference<>()) + return_internal_reference<>()) .def("find_account_re", &account_t::find_account, - return_internal_reference<>()) + return_internal_reference<>()) .def("add_post", &account_t::add_post) .def("remove_post", &account_t::remove_post) @@ -208,24 +208,24 @@ void export_account() .def("__getitem__", accounts_getitem, return_internal_reference<>()) .def("__iter__", python::range<return_internal_reference<> > - (&account_t::accounts_begin, &account_t::accounts_end)) + (&account_t::accounts_begin, &account_t::accounts_end)) .def("accounts", python::range<return_internal_reference<> > - (&account_t::accounts_begin, &account_t::accounts_end)) + (&account_t::accounts_begin, &account_t::accounts_end)) .def("posts", python::range<return_internal_reference<> > - (&account_t::posts_begin, &account_t::posts_end)) + (&account_t::posts_begin, &account_t::posts_end)) .def("has_xdata", &account_t::has_xdata) .def("clear_xdata", &account_t::clear_xdata) .def("xdata", py_xdata, - return_internal_reference<>()) + return_internal_reference<>()) .def("amount", &account_t::amount) .def("total", &account_t::total) .def("self_details", &account_t::self_details, - return_internal_reference<>()) + return_internal_reference<>()) .def("family_details", &account_t::family_details, - return_internal_reference<>()) + return_internal_reference<>()) .def("has_xflags", &account_t::has_xflags) .def("children_with_flags", &account_t::children_with_flags) diff --git a/src/py_amount.cc b/src/py_amount.cc index c5962446..3cb9f0eb 100644 --- a/src/py_amount.cc +++ b/src/py_amount.cc @@ -48,12 +48,12 @@ namespace { return amount.value(CURRENT_TIME()); } boost::optional<amount_t> py_value_1(const amount_t& amount, - commodity_t& in_terms_of) { + commodity_t& in_terms_of) { return amount.value(CURRENT_TIME(), in_terms_of); } boost::optional<amount_t> py_value_2(const amount_t& amount, - commodity_t& in_terms_of, - datetime_t& moment) { + commodity_t& in_terms_of, + datetime_t& moment) { return amount.value(moment, in_terms_of); } @@ -63,7 +63,7 @@ namespace { amount.parse(instr, flags); } else { PyErr_SetString(PyExc_IOError, - _("Argument to amount.parse(file) is not a file object")); + _("Argument to amount.parse(file) is not a file object")); } } void py_parse_1(amount_t& amount, object in) { @@ -83,7 +83,7 @@ namespace { amount.print(outstr); } else { PyErr_SetString(PyExc_IOError, - _("Argument to amount.print_(file) is not a file object")); + _("Argument to amount.print_(file) is not a file object")); } } @@ -104,9 +104,9 @@ namespace { } // unnamed namespace -#define EXC_TRANSLATOR(type) \ - void exc_translate_ ## type(const type& err) { \ - PyErr_SetString(PyExc_ArithmeticError, err.what()); \ +#define EXC_TRANSLATOR(type) \ + void exc_translate_ ## type(const type& err) { \ + PyErr_SetString(PyExc_ArithmeticError, err.what()); \ } EXC_TRANSLATOR(amount_error) @@ -120,24 +120,24 @@ void export_amount() .staticmethod("shutdown") .add_static_property("is_initialized", - make_getter(&amount_t::is_initialized), - make_setter(&amount_t::is_initialized)) + make_getter(&amount_t::is_initialized), + make_setter(&amount_t::is_initialized)) .add_static_property("stream_fullstrings", - make_getter(&amount_t::stream_fullstrings), - make_setter(&amount_t::stream_fullstrings)) + make_getter(&amount_t::stream_fullstrings), + make_setter(&amount_t::stream_fullstrings)) .def(init<long>()) .def(init<std::string>()) .def("exact", &amount_t::exact, args("value"), - _("Construct an amount object whose display precision is always equal to its\n\ + _("Construct an amount object whose display precision is always equal to its\n\ internal precision.")) .staticmethod("exact") .def(init<amount_t>()) .def("compare", &amount_t::compare, args("amount"), - _("Compare two amounts for equality, returning <0, 0 or >0.")) + _("Compare two amounts for equality, returning <0, 0 or >0.")) .def(self == self) .def(self == long()) @@ -168,40 +168,40 @@ internal precision.")) .def(self += self) .def(self += long()) - .def(self + self) - .def(self + long()) - .def(long() + self) + .def(self + self) + .def(self + long()) + .def(long() + self) .def(self -= self) .def(self -= long()) - .def(self - self) - .def(self - long()) - .def(long() - self) + .def(self - self) + .def(self - long()) + .def(long() - self) .def(self *= self) .def(self *= long()) - .def(self * self) - .def(self * long()) - .def(long() * self) + .def(self * self) + .def(self * long()) + .def(long() * self) .def(self /= self) .def(self /= long()) - .def(self / self) - .def(self / long()) - .def(long() / self) + .def(self / self) + .def(self / long()) + .def(long() / self) .add_property("precision", &amount_t::precision) .add_property("display_precision", &amount_t::display_precision) .add_property("keep_precision", - &amount_t::keep_precision, - &amount_t::set_keep_precision) + &amount_t::keep_precision, + &amount_t::set_keep_precision) .def("negated", &amount_t::negated) .def("in_place_negate", &amount_t::in_place_negate, - return_internal_reference<>()) + return_internal_reference<>()) .def(- self) .def("abs", &amount_t::abs) @@ -211,27 +211,27 @@ internal precision.")) .def("rounded", &amount_t::rounded) .def("in_place_round", &amount_t::in_place_round, - return_internal_reference<>()) + return_internal_reference<>()) .def("truncated", &amount_t::truncated) .def("in_place_truncate", &amount_t::in_place_truncate, - return_internal_reference<>()) + return_internal_reference<>()) .def("floored", &amount_t::floored) .def("in_place_floor", &amount_t::in_place_floor, - return_internal_reference<>()) + return_internal_reference<>()) .def("unrounded", &amount_t::unrounded) .def("in_place_unround", &amount_t::in_place_unround, - return_internal_reference<>()) + return_internal_reference<>()) .def("reduced", &amount_t::reduced) .def("in_place_reduce", &amount_t::in_place_reduce, - return_internal_reference<>()) + return_internal_reference<>()) .def("unreduced", &amount_t::unreduced) .def("in_place_unreduce", &amount_t::in_place_unreduce, - return_internal_reference<>()) + return_internal_reference<>()) .def("value", py_value_0) .def("value", py_value_1, args("in_terms_of")) @@ -260,10 +260,10 @@ internal precision.")) .def("quantity_string", &amount_t::quantity_string) .add_property("commodity", - make_function(&amount_t::commodity, - return_value_policy<reference_existing_object>()), - make_function(&amount_t::set_commodity, - with_custodian_and_ward<1, 2>())) + make_function(&amount_t::commodity, + return_value_policy<reference_existing_object>()), + make_function(&amount_t::set_commodity, + with_custodian_and_ward<1, 2>())) .def("has_commodity", &amount_t::has_commodity) .def("clear_commodity", &amount_t::clear_commodity) @@ -272,8 +272,8 @@ internal precision.")) .def("annotate", &amount_t::annotate) .def("has_annotation", &amount_t::has_annotation) .add_property("annotation", - make_function(py_amount_annotation, - return_internal_reference<>())) + make_function(py_amount_annotation, + return_internal_reference<>())) .def("strip_annotations", py_strip_annotations_0) .def("strip_annotations", py_strip_annotations_1) diff --git a/src/py_balance.cc b/src/py_balance.cc index 03a73ff6..eba5761d 100644 --- a/src/py_balance.cc +++ b/src/py_balance.cc @@ -48,12 +48,12 @@ namespace { return balance.value(CURRENT_TIME()); } boost::optional<balance_t> py_value_1(const balance_t& balance, - commodity_t& in_terms_of) { + commodity_t& in_terms_of) { return balance.value(CURRENT_TIME(), in_terms_of); } boost::optional<balance_t> py_value_2(const balance_t& balance, - commodity_t& in_terms_of, - datetime_t& moment) { + commodity_t& in_terms_of, + datetime_t& moment) { return balance.value(moment, in_terms_of); } @@ -64,7 +64,7 @@ namespace { boost::optional<amount_t> py_commodity_amount_1(const balance_t& balance, - const boost::optional<const commodity_t&>& commodity) { + const boost::optional<const commodity_t&>& commodity) { return balance.commodity_amount(commodity); } @@ -74,7 +74,7 @@ namespace { balance.print(outstr); } else { PyErr_SetString(PyExc_IOError, - _("Argument to balance.print_(file) is not a file object")); + _("Argument to balance.print_(file) is not a file object")); } } @@ -111,9 +111,9 @@ namespace { } // unnamed namespace -#define EXC_TRANSLATOR(type) \ - void exc_translate_ ## type(const type& err) { \ - PyErr_SetString(PyExc_ArithmeticError, err.what()); \ +#define EXC_TRANSLATOR(type) \ + void exc_translate_ ## type(const type& err) { \ + PyErr_SetString(PyExc_ArithmeticError, err.what()); \ } EXC_TRANSLATOR(balance_error) @@ -162,7 +162,7 @@ void export_balance() .def("negated", &balance_t::negated) .def("in_place_negate", &balance_t::in_place_negate, - return_internal_reference<>()) + return_internal_reference<>()) .def(- self) .def("abs", &balance_t::abs) @@ -173,27 +173,27 @@ void export_balance() .def("rounded", &balance_t::rounded) .def("in_place_round", &balance_t::in_place_round, - return_internal_reference<>()) + return_internal_reference<>()) .def("truncated", &balance_t::truncated) .def("in_place_truncate", &balance_t::in_place_truncate, - return_internal_reference<>()) + return_internal_reference<>()) .def("floored", &balance_t::floored) .def("in_place_floor", &balance_t::in_place_floor, - return_internal_reference<>()) + return_internal_reference<>()) .def("unrounded", &balance_t::unrounded) .def("in_place_unround", &balance_t::in_place_unround, - return_internal_reference<>()) + return_internal_reference<>()) .def("reduced", &balance_t::reduced) .def("in_place_reduce", &balance_t::in_place_reduce, - return_internal_reference<>()) + return_internal_reference<>()) .def("unreduced", &balance_t::unreduced) .def("in_place_unreduce", &balance_t::in_place_unreduce, - return_internal_reference<>()) + return_internal_reference<>()) .def("value", py_value_0) .def("value", py_value_1, args("in_terms_of")) diff --git a/src/py_commodity.cc b/src/py_commodity.cc index fc7e8c3e..783171dd 100644 --- a/src/py_commodity.cc +++ b/src/py_commodity.cc @@ -44,38 +44,38 @@ using namespace boost::python; namespace { commodity_t * py_create_1(commodity_pool_t& pool, - const string& symbol) + const string& symbol) { return pool.create(symbol); } - commodity_t * py_create_2(commodity_pool_t& pool, - const string& symbol, - const annotation_t& details) + commodity_t * py_create_2(commodity_pool_t& pool, + const string& symbol, + const annotation_t& details) { return pool.create(symbol, details); } commodity_t * py_find_or_create_1(commodity_pool_t& pool, - const string& symbol) + const string& symbol) { return pool.find_or_create(symbol); } - commodity_t * py_find_or_create_2(commodity_pool_t& pool, - const string& symbol, - const annotation_t& details) + commodity_t * py_find_or_create_2(commodity_pool_t& pool, + const string& symbol, + const annotation_t& details) { return pool.find_or_create(symbol, details); } commodity_t * py_find_1(commodity_pool_t& pool, - const string& name) + const string& name) { return pool.find(name); } commodity_t * py_find_2(commodity_pool_t& pool, - const string& symbol, - const annotation_t& details) + const string& symbol, + const annotation_t& details) { return pool.find(symbol, details); } @@ -83,25 +83,25 @@ namespace { // Exchange one commodity for another, while recording the factored price. void py_exchange_2(commodity_pool_t& pool, - commodity_t& commodity, - const amount_t& per_unit_cost) + commodity_t& commodity, + const amount_t& per_unit_cost) { pool.exchange(commodity, per_unit_cost, CURRENT_TIME()); } void py_exchange_3(commodity_pool_t& pool, - commodity_t& commodity, - const amount_t& per_unit_cost, - const datetime_t& moment) + commodity_t& commodity, + const amount_t& per_unit_cost, + const datetime_t& moment) { pool.exchange(commodity, per_unit_cost, moment); } - cost_breakdown_t py_exchange_5(commodity_pool_t& pool, - const amount_t& amount, - const amount_t& cost, - const bool is_per_unit, - const boost::optional<datetime_t>& moment, - const boost::optional<string>& tag) + cost_breakdown_t py_exchange_5(commodity_pool_t& pool, + const amount_t& amount, + const amount_t& cost, + const bool is_per_unit, + const boost::optional<datetime_t>& moment, + const boost::optional<string>& tag) { return pool.exchange(amount, cost, is_per_unit, moment, tag); } @@ -112,7 +112,7 @@ namespace { pool.commodities.find(symbol); if (i == pool.commodities.end()) { PyErr_SetString(PyExc_ValueError, - (string("Could not find commodity ") + symbol).c_str()); + (string("Could not find commodity ") + symbol).c_str()); throw boost::python::error_already_set(); } return (*i).second; @@ -178,12 +178,12 @@ namespace { } void py_add_price_2(commodity_t& commodity, - const datetime_t& date, const amount_t& price) { + const datetime_t& date, const amount_t& price) { commodity.add_price(date, price); } void py_add_price_3(commodity_t& commodity, const datetime_t& date, - const amount_t& price, const bool reflexive) { + const amount_t& price, const bool reflexive) { commodity.add_price(date, price, reflexive); } @@ -212,7 +212,7 @@ namespace { return comm.strip_annotations(keep_details_t()); } commodity_t& py_strip_annotations_1(commodity_t& comm, - const keep_details_t& keep) { + const keep_details_t& keep) { return comm.strip_annotations(keep); } @@ -220,7 +220,7 @@ namespace { return comm.strip_annotations(keep_details_t()); } commodity_t& py_strip_ann_annotations_1(annotated_commodity_t& comm, - const keep_details_t& keep) { + const keep_details_t& keep) { return comm.strip_annotations(keep); } @@ -228,7 +228,7 @@ namespace { return ann.price; } boost::optional<amount_t> py_set_price(annotation_t& ann, - const boost::optional<amount_t>& price) { + const boost::optional<amount_t>& price) { return ann.price = price; } @@ -243,41 +243,41 @@ void export_commodity() class_< commodity_pool_t, shared_ptr<commodity_pool_t>, boost::noncopyable > ("CommodityPool", no_init) .add_property("null_commodity", - make_getter(&commodity_pool_t::null_commodity, - return_internal_reference<>())) + make_getter(&commodity_pool_t::null_commodity, + return_internal_reference<>())) .add_property("default_commodity", - make_getter(&commodity_pool_t::default_commodity, - return_internal_reference<>()), - make_setter(&commodity_pool_t::default_commodity, - with_custodian_and_ward<1, 2>())) + make_getter(&commodity_pool_t::default_commodity, + return_internal_reference<>()), + make_setter(&commodity_pool_t::default_commodity, + with_custodian_and_ward<1, 2>())) .add_property("keep_base", - make_getter(&commodity_pool_t::keep_base), - make_setter(&commodity_pool_t::keep_base)) + make_getter(&commodity_pool_t::keep_base), + make_setter(&commodity_pool_t::keep_base)) .add_property("price_db", - make_getter(&commodity_pool_t::price_db), - make_setter(&commodity_pool_t::price_db)) + make_getter(&commodity_pool_t::price_db), + make_setter(&commodity_pool_t::price_db)) .add_property("quote_leeway", - make_getter(&commodity_pool_t::quote_leeway), - make_setter(&commodity_pool_t::quote_leeway)) + make_getter(&commodity_pool_t::quote_leeway), + make_setter(&commodity_pool_t::quote_leeway)) .add_property("get_quotes", - make_getter(&commodity_pool_t::get_quotes), - make_setter(&commodity_pool_t::get_quotes)) + make_getter(&commodity_pool_t::get_quotes), + make_setter(&commodity_pool_t::get_quotes)) .add_property("get_commodity_quote", - make_getter(&commodity_pool_t::get_commodity_quote), - make_setter(&commodity_pool_t::get_commodity_quote)) + make_getter(&commodity_pool_t::get_commodity_quote), + make_setter(&commodity_pool_t::get_commodity_quote)) .def("make_qualified_name", &commodity_pool_t::make_qualified_name) .def("create", py_create_1, - return_value_policy<reference_existing_object>()) + return_value_policy<reference_existing_object>()) .def("create", py_create_2, - return_value_policy<reference_existing_object>()) + return_value_policy<reference_existing_object>()) .def("find_or_create", py_find_or_create_1, - return_value_policy<reference_existing_object>()) + return_value_policy<reference_existing_object>()) .def("find_or_create", py_find_or_create_2, - return_value_policy<reference_existing_object>()) + return_value_policy<reference_existing_object>()) .def("find", py_find_1, return_value_policy<reference_existing_object>()) .def("find", py_find_2, return_value_policy<reference_existing_object>()) @@ -288,46 +288,46 @@ void export_commodity() .def("parse_price_directive", &commodity_pool_t::parse_price_directive) .def("parse_price_expression", &commodity_pool_t::parse_price_expression, - return_value_policy<reference_existing_object>()) + return_value_policy<reference_existing_object>()) .def("__getitem__", py_pool_getitem, - return_value_policy<reference_existing_object>()) + return_value_policy<reference_existing_object>()) .def("keys", py_pool_keys) .def("has_key", py_pool_contains) .def("__contains__", py_pool_contains) .def("__iter__", - python::range<return_value_policy<reference_existing_object> > - (py_pool_commodities_begin, py_pool_commodities_end)) + python::range<return_value_policy<reference_existing_object> > + (py_pool_commodities_begin, py_pool_commodities_end)) .def("iteritems", - python::range<return_value_policy<reference_existing_object> > - (py_pool_commodities_begin, py_pool_commodities_end)) + python::range<return_value_policy<reference_existing_object> > + (py_pool_commodities_begin, py_pool_commodities_end)) .def("iterkeys", python::range<>(py_pool_commodities_keys_begin, - py_pool_commodities_keys_end)) + py_pool_commodities_keys_end)) .def("itervalues", - python::range<return_value_policy<reference_existing_object> > - (py_pool_commodities_values_begin, py_pool_commodities_values_end)) + python::range<return_value_policy<reference_existing_object> > + (py_pool_commodities_values_begin, py_pool_commodities_values_end)) ; map_value_type_converter<commodity_pool_t::commodities_map>(); scope().attr("commodities") = commodity_pool_t::current_pool; - scope().attr("COMMODITY_STYLE_DEFAULTS") = COMMODITY_STYLE_DEFAULTS; - scope().attr("COMMODITY_STYLE_SUFFIXED") = COMMODITY_STYLE_SUFFIXED; - scope().attr("COMMODITY_STYLE_SEPARATED") = COMMODITY_STYLE_SEPARATED; + scope().attr("COMMODITY_STYLE_DEFAULTS") = COMMODITY_STYLE_DEFAULTS; + scope().attr("COMMODITY_STYLE_SUFFIXED") = COMMODITY_STYLE_SUFFIXED; + scope().attr("COMMODITY_STYLE_SEPARATED") = COMMODITY_STYLE_SEPARATED; scope().attr("COMMODITY_STYLE_DECIMAL_COMMA") = COMMODITY_STYLE_DECIMAL_COMMA; - scope().attr("COMMODITY_STYLE_THOUSANDS") = COMMODITY_STYLE_THOUSANDS; - scope().attr("COMMODITY_NOMARKET") = COMMODITY_NOMARKET; - scope().attr("COMMODITY_BUILTIN") = COMMODITY_BUILTIN; - scope().attr("COMMODITY_WALKED") = COMMODITY_WALKED; - scope().attr("COMMODITY_KNOWN") = COMMODITY_KNOWN; - scope().attr("COMMODITY_PRIMARY") = COMMODITY_PRIMARY; + scope().attr("COMMODITY_STYLE_THOUSANDS") = COMMODITY_STYLE_THOUSANDS; + scope().attr("COMMODITY_NOMARKET") = COMMODITY_NOMARKET; + scope().attr("COMMODITY_BUILTIN") = COMMODITY_BUILTIN; + scope().attr("COMMODITY_WALKED") = COMMODITY_WALKED; + scope().attr("COMMODITY_KNOWN") = COMMODITY_KNOWN; + scope().attr("COMMODITY_PRIMARY") = COMMODITY_PRIMARY; class_< commodity_t, boost::noncopyable > ("Commodity", no_init) #if 1 .add_property("flags", - &supports_flags<uint_least16_t>::flags, - &supports_flags<uint_least16_t>::set_flags) + &supports_flags<uint_least16_t>::flags, + &supports_flags<uint_least16_t>::set_flags) .def("has_flags", &delegates_flags<uint_least16_t>::has_flags) .def("clear_flags", &delegates_flags<uint_least16_t>::clear_flags) .def("add_flags", &delegates_flags<uint_least16_t>::add_flags) @@ -335,8 +335,8 @@ void export_commodity() #endif .add_static_property("decimal_comma_by_default", - make_getter(&commodity_t::decimal_comma_by_default), - make_setter(&commodity_t::decimal_comma_by_default)) + make_getter(&commodity_t::decimal_comma_by_default), + make_setter(&commodity_t::decimal_comma_by_default)) .def("__str__", &commodity_t::symbol) .def("__unicode__", py_commodity_unicode) @@ -348,18 +348,18 @@ void export_commodity() .staticmethod("symbol_needs_quotes") .add_property("referent", - make_function(py_commodity_referent, - return_value_policy<reference_existing_object>())) + make_function(py_commodity_referent, + return_value_policy<reference_existing_object>())) .def("has_annotation", &commodity_t::has_annotation) .def("strip_annotations", py_strip_annotations_0, - return_value_policy<reference_existing_object>()) + return_value_policy<reference_existing_object>()) .def("strip_annotations", py_strip_annotations_1, - return_value_policy<reference_existing_object>()) + return_value_policy<reference_existing_object>()) .def("write_annotations", &commodity_t::write_annotations) .def("pool", &commodity_t::pool, - return_value_policy<reference_existing_object>()) + return_value_policy<reference_existing_object>()) .add_property("base_symbol", &commodity_t::base_symbol) .add_property("symbol", &commodity_t::symbol) @@ -368,14 +368,14 @@ void export_commodity() .add_property("name", &commodity_t::name, &commodity_t::set_name) .add_property("note", &commodity_t::note, &commodity_t::set_note) .add_property("precision", &commodity_t::precision, - &commodity_t::set_precision) + &commodity_t::set_precision) .add_property("smaller", &commodity_t::smaller, &commodity_t::set_smaller) .add_property("larger", &commodity_t::larger, &commodity_t::set_larger) .def("add_price", py_add_price_2) .def("add_price", py_add_price_3) .def("remove_price", &commodity_t::remove_price, - with_custodian_and_ward<1, 3>()) + with_custodian_and_ward<1, 3>()) .def("find_price", &commodity_t::find_price) .def("check_for_updated_price", &commodity_t::check_for_updated_price) @@ -385,7 +385,7 @@ void export_commodity() class_< annotation_t > ("Annotation", no_init) #if 1 .add_property("flags", &supports_flags<>::flags, - &supports_flags<>::set_flags) + &supports_flags<>::set_flags) .def("has_flags", &supports_flags<>::has_flags) .def("clear_flags", &supports_flags<>::clear_flags) .def("add_flags", &supports_flags<>::add_flags) @@ -394,11 +394,11 @@ void export_commodity() .add_property("price", py_price, py_set_price) .add_property("date", - make_getter(&annotation_t::date), - make_setter(&annotation_t::date)) + make_getter(&annotation_t::date), + make_setter(&annotation_t::date)) .add_property("tag", - make_getter(&annotation_t::tag), - make_setter(&annotation_t::tag)) + make_getter(&annotation_t::tag), + make_setter(&annotation_t::tag)) .def("__nonzero__", &annotation_t::operator bool) @@ -411,17 +411,17 @@ void export_commodity() .def(init<bool, bool, bool, bool>()) .add_property("keep_price", - make_getter(&keep_details_t::keep_price), - make_setter(&keep_details_t::keep_price)) + make_getter(&keep_details_t::keep_price), + make_setter(&keep_details_t::keep_price)) .add_property("keep_date", - make_getter(&keep_details_t::keep_date), - make_setter(&keep_details_t::keep_date)) + make_getter(&keep_details_t::keep_date), + make_setter(&keep_details_t::keep_date)) .add_property("keep_tag", - make_getter(&keep_details_t::keep_tag), - make_setter(&keep_details_t::keep_tag)) + make_getter(&keep_details_t::keep_tag), + make_setter(&keep_details_t::keep_tag)) .add_property("only_actuals", - make_getter(&keep_details_t::only_actuals), - make_setter(&keep_details_t::only_actuals)) + make_getter(&keep_details_t::only_actuals), + make_setter(&keep_details_t::only_actuals)) .def("keep_all", py_keep_all_0) .def("keep_all", py_keep_all_1) @@ -433,20 +433,20 @@ void export_commodity() annotated_commodity_t, boost::noncopyable > ("AnnotatedCommodity", no_init) .add_property("details", - make_getter(&annotated_commodity_t::details), - make_setter(&annotated_commodity_t::details)) + make_getter(&annotated_commodity_t::details), + make_setter(&annotated_commodity_t::details)) .def(self == self) .def(self == other<commodity_t>()) .add_property("referent", - make_function(py_annotated_commodity_referent, - return_value_policy<reference_existing_object>())) + make_function(py_annotated_commodity_referent, + return_value_policy<reference_existing_object>())) .def("strip_annotations", py_strip_ann_annotations_0, - return_value_policy<reference_existing_object>()) + return_value_policy<reference_existing_object>()) .def("strip_annotations", py_strip_ann_annotations_1, - return_value_policy<reference_existing_object>()) + return_value_policy<reference_existing_object>()) .def("write_annotations", &annotated_commodity_t::write_annotations) ; } diff --git a/src/py_format.cc b/src/py_format.cc index 36f89ae5..ce7052ac 100644 --- a/src/py_format.cc +++ b/src/py_format.cc @@ -37,9 +37,9 @@ namespace ledger { using namespace boost::python; -#define EXC_TRANSLATOR(type) \ - void exc_translate_ ## type(const type& err) { \ - PyErr_SetString(PyExc_ArithmeticError, err.what()); \ +#define EXC_TRANSLATOR(type) \ + void exc_translate_ ## type(const type& err) { \ + PyErr_SetString(PyExc_ArithmeticError, err.what()); \ } //EXC_TRANSLATOR(format_error) diff --git a/src/py_item.cc b/src/py_item.cc index edebd532..0e95f24f 100644 --- a/src/py_item.cc +++ b/src/py_item.cc @@ -49,26 +49,26 @@ namespace { return item.has_tag(tag_mask); } bool py_has_tag_2m(item_t& item, const mask_t& tag_mask, - const boost::optional<mask_t>& value_mask) { + const boost::optional<mask_t>& value_mask) { return item.has_tag(tag_mask, value_mask); } - boost::optional<string> py_get_tag_1s(item_t& item, const string& tag) { + boost::optional<value_t> py_get_tag_1s(item_t& item, const string& tag) { return item.get_tag(tag); } - boost::optional<string> py_get_tag_1m(item_t& item, const mask_t& tag_mask) { + boost::optional<value_t> py_get_tag_1m(item_t& item, const mask_t& tag_mask) { return item.get_tag(tag_mask); } - boost::optional<string> py_get_tag_2m(item_t& item, const mask_t& tag_mask, - const boost::optional<mask_t>& value_mask) { + boost::optional<value_t> py_get_tag_2m(item_t& item, const mask_t& tag_mask, + const boost::optional<mask_t>& value_mask) { return item.get_tag(tag_mask, value_mask); } } // unnamed namespace -#define EXC_TRANSLATOR(type) \ - void exc_translate_ ## type(const type& err) { \ - PyErr_SetString(PyExc_ArithmeticError, err.what()); \ +#define EXC_TRANSLATOR(type) \ + void exc_translate_ ## type(const type& err) { \ + PyErr_SetString(PyExc_ArithmeticError, err.what()); \ } //EXC_TRANSLATOR(item_error) @@ -77,25 +77,25 @@ void export_item() { class_< position_t > ("Position") .add_property("pathname", - make_getter(&position_t::pathname), - make_setter(&position_t::pathname)) + make_getter(&position_t::pathname), + make_setter(&position_t::pathname)) .add_property("beg_pos", - make_getter(&position_t::beg_pos), - make_setter(&position_t::beg_pos)) + make_getter(&position_t::beg_pos), + make_setter(&position_t::beg_pos)) .add_property("beg_line", - make_getter(&position_t::beg_line), - make_setter(&position_t::beg_line)) + make_getter(&position_t::beg_line), + make_setter(&position_t::beg_line)) .add_property("end_pos", - make_getter(&position_t::end_pos), - make_setter(&position_t::end_pos)) + make_getter(&position_t::end_pos), + make_setter(&position_t::end_pos)) .add_property("end_line", - make_getter(&position_t::end_line), - make_setter(&position_t::end_line)) + make_getter(&position_t::end_line), + make_setter(&position_t::end_line)) ; - scope().attr("ITEM_NORMAL") = ITEM_NORMAL; + scope().attr("ITEM_NORMAL") = ITEM_NORMAL; scope().attr("ITEM_GENERATED") = ITEM_GENERATED; - scope().attr("ITEM_TEMP") = ITEM_TEMP; + scope().attr("ITEM_TEMP") = ITEM_TEMP; enum_< item_t::state_t > ("State") .value("Uncleared", item_t::UNCLEARED) @@ -110,7 +110,7 @@ void export_item() #endif #if 1 .add_property("flags", &supports_flags<>::flags, - &supports_flags<>::set_flags) + &supports_flags<>::set_flags) .def("has_flags", &supports_flags<>::has_flags) .def("clear_flags", &supports_flags<>::clear_flags) .def("add_flags", &supports_flags<>::add_flags) @@ -118,14 +118,14 @@ void export_item() #endif .add_property("note", - make_getter(&item_t::note), - make_setter(&item_t::note)) + make_getter(&item_t::note), + make_setter(&item_t::note)) .add_property("pos", - make_getter(&item_t::pos), - make_setter(&item_t::pos)) + make_getter(&item_t::pos), + make_setter(&item_t::pos)) .add_property("metadata", - make_getter(&item_t::metadata), - make_setter(&item_t::metadata)) + make_getter(&item_t::metadata), + make_setter(&item_t::metadata)) .def("copy_details", &item_t::copy_details) @@ -148,12 +148,12 @@ void export_item() .def("append_note", &item_t::append_note) .add_static_property("use_effective_date", - make_getter(&item_t::use_effective_date), - make_setter(&item_t::use_effective_date)) + make_getter(&item_t::use_effective_date), + make_setter(&item_t::use_effective_date)) .add_property("date", &item_t::date, make_setter(&item_t::_date)) .add_property("effective_date", &item_t::effective_date, - make_setter(&item_t::_date_eff)) + make_setter(&item_t::_date_eff)) .add_property("state", &item_t::state, &item_t::set_state) diff --git a/src/py_journal.cc b/src/py_journal.cc index cd25d134..fc4f671b 100644 --- a/src/py_journal.cc +++ b/src/py_journal.cc @@ -126,7 +126,7 @@ namespace { } account_t * py_find_account_2(journal_t& journal, const string& name, - const bool auto_create) + const bool auto_create) { return journal.find_account(name, auto_create); } @@ -138,14 +138,14 @@ namespace { struct collector_wrapper { - journal_t& journal; + journal_t& journal; report_t report; collect_posts * posts_collector; post_handler_ptr chain; collector_wrapper(journal_t& _journal, report_t& base) : journal(_journal), report(base), - posts_collector(new collect_posts) {} + posts_collector(new collect_posts) {} ~collector_wrapper() { journal.clear_xdata(); } @@ -167,31 +167,31 @@ namespace { { if (journal.has_xdata()) { PyErr_SetString(PyExc_RuntimeError, - _("Cannot have multiple journal collections open at once")); + _("Cannot have multiple journal collections open at once")); throw_error_already_set(); } report_t& current_report(downcast<report_t>(*scope_t::default_scope)); shared_ptr<collector_wrapper> coll(new collector_wrapper(journal, - current_report)); + current_report)); std::auto_ptr<journal_t> save_journal (current_report.session.journal.release()); current_report.session.journal.reset(&journal); try { strings_list remaining = - process_arguments(split_arguments(query.c_str()), coll->report); + process_arguments(split_arguments(query.c_str()), coll->report); coll->report.normalize_options("register"); value_t args; foreach (const string& arg, remaining) - args.push_back(string_value(arg)); + args.push_back(string_value(arg)); coll->report.parse_query_args(args, "@Journal.collect"); journal_posts_iterator walker(coll->journal); coll->chain = - chain_post_handlers(post_handler_ptr(coll->posts_collector), - coll->report); + chain_post_handlers(post_handler_ptr(coll->posts_collector), + coll->report); pass_down_posts(coll->chain, walker); } catch (...) { @@ -227,36 +227,36 @@ void export_journal() shared_ptr<collect_posts>, boost::noncopyable >("PostCollector") .def("__len__", &collect_posts::length) .def("__iter__", python::range<return_internal_reference<1, - with_custodian_and_ward_postcall<1, 0> > > - (&collect_posts::begin, &collect_posts::end)) + with_custodian_and_ward_postcall<1, 0> > > + (&collect_posts::begin, &collect_posts::end)) ; class_< collector_wrapper, shared_ptr<collector_wrapper>, boost::noncopyable >("PostCollectorWrapper", no_init) .def("__len__", &collector_wrapper::length) .def("__getitem__", posts_getitem, return_internal_reference<1, - with_custodian_and_ward_postcall<0, 1> >()) + with_custodian_and_ward_postcall<0, 1> >()) .def("__iter__", - python::range<return_value_policy<reference_existing_object, - with_custodian_and_ward_postcall<0, 1> > > - (&collector_wrapper::begin, &collector_wrapper::end)) + python::range<return_value_policy<reference_existing_object, + with_custodian_and_ward_postcall<0, 1> > > + (&collector_wrapper::begin, &collector_wrapper::end)) ; class_< journal_t::fileinfo_t > ("FileInfo") .def(init<path>()) .add_property("filename", - make_getter(&journal_t::fileinfo_t::filename), - make_setter(&journal_t::fileinfo_t::filename)) + make_getter(&journal_t::fileinfo_t::filename), + make_setter(&journal_t::fileinfo_t::filename)) .add_property("size", - make_getter(&journal_t::fileinfo_t::size), - make_setter(&journal_t::fileinfo_t::size)) + make_getter(&journal_t::fileinfo_t::size), + make_setter(&journal_t::fileinfo_t::size)) .add_property("modtime", - make_getter(&journal_t::fileinfo_t::modtime), - make_setter(&journal_t::fileinfo_t::modtime)) + make_getter(&journal_t::fileinfo_t::modtime), + make_setter(&journal_t::fileinfo_t::modtime)) .add_property("from_stream", - make_getter(&journal_t::fileinfo_t::from_stream), - make_setter(&journal_t::fileinfo_t::from_stream)) + make_getter(&journal_t::fileinfo_t::from_stream), + make_setter(&journal_t::fileinfo_t::from_stream)) ; class_< journal_t, boost::noncopyable > ("Journal") @@ -264,28 +264,28 @@ void export_journal() .def(init<string>()) .add_property("master", - make_getter(&journal_t::master, - return_internal_reference<1, - with_custodian_and_ward_postcall<1, 0> >())) + make_getter(&journal_t::master, + return_internal_reference<1, + with_custodian_and_ward_postcall<1, 0> >())) .add_property("bucket", - make_getter(&journal_t::bucket, - return_internal_reference<1, - with_custodian_and_ward_postcall<1, 0> >()), - make_setter(&journal_t::bucket)) + make_getter(&journal_t::bucket, + return_internal_reference<1, + with_custodian_and_ward_postcall<1, 0> >()), + make_setter(&journal_t::bucket)) .add_property("was_loaded", make_getter(&journal_t::was_loaded)) .def("add_account", &journal_t::add_account) .def("remove_account", &journal_t::remove_account) .def("find_account", py_find_account_1, - return_internal_reference<1, - with_custodian_and_ward_postcall<0, 1> >()) + return_internal_reference<1, + with_custodian_and_ward_postcall<0, 1> >()) .def("find_account", py_find_account_2, - return_internal_reference<1, - with_custodian_and_ward_postcall<0, 1> >()) + return_internal_reference<1, + with_custodian_and_ward_postcall<0, 1> >()) .def("find_account_re", &journal_t::find_account_re, - return_internal_reference<1, - with_custodian_and_ward_postcall<0, 1> >()) + return_internal_reference<1, + with_custodian_and_ward_postcall<0, 1> >()) .def("add_xact", &journal_t::add_xact) .def("remove_xact", &journal_t::remove_xact) @@ -293,20 +293,20 @@ void export_journal() .def("__len__", xacts_len) #if 0 .def("__getitem__", xacts_getitem, - return_internal_reference<1, - with_custodian_and_ward_postcall<0, 1> >()) + return_internal_reference<1, + with_custodian_and_ward_postcall<0, 1> >()) #endif .def("__iter__", python::range<return_internal_reference<> > - (&journal_t::xacts_begin, &journal_t::xacts_end)) + (&journal_t::xacts_begin, &journal_t::xacts_end)) .def("xacts", python::range<return_internal_reference<> > - (&journal_t::xacts_begin, &journal_t::xacts_end)) + (&journal_t::xacts_begin, &journal_t::xacts_end)) .def("auto_xacts", python::range<return_internal_reference<> > - (&journal_t::auto_xacts_begin, &journal_t::auto_xacts_end)) + (&journal_t::auto_xacts_begin, &journal_t::auto_xacts_end)) .def("period_xacts", python::range<return_internal_reference<> > - (&journal_t::period_xacts_begin, &journal_t::period_xacts_end)) + (&journal_t::period_xacts_begin, &journal_t::period_xacts_end)) .def("sources", python::range<return_internal_reference<> > - (&journal_t::sources_begin, &journal_t::sources_end)) + (&journal_t::sources_begin, &journal_t::sources_end)) .def("read", py_read) diff --git a/src/py_post.cc b/src/py_post.cc index e4a50980..537289b3 100644 --- a/src/py_post.cc +++ b/src/py_post.cc @@ -48,18 +48,18 @@ namespace { return post.has_tag(tag_mask); } bool py_has_tag_2m(post_t& post, const mask_t& tag_mask, - const boost::optional<mask_t>& value_mask) { + const boost::optional<mask_t>& value_mask) { return post.has_tag(tag_mask, value_mask); } - boost::optional<string> py_get_tag_1s(post_t& post, const string& tag) { + boost::optional<value_t> py_get_tag_1s(post_t& post, const string& tag) { return post.get_tag(tag); } - boost::optional<string> py_get_tag_1m(post_t& post, const mask_t& tag_mask) { + boost::optional<value_t> py_get_tag_1m(post_t& post, const mask_t& tag_mask) { return post.get_tag(tag_mask); } - boost::optional<string> py_get_tag_2m(post_t& post, const mask_t& tag_mask, - const boost::optional<mask_t>& value_mask) { + boost::optional<value_t> py_get_tag_2m(post_t& post, const mask_t& tag_mask, + const boost::optional<mask_t>& value_mask) { return post.get_tag(tag_mask, value_mask); } @@ -88,8 +88,8 @@ void export_post() class_< post_t::xdata_t > ("PostingXData") #if 1 .add_property("flags", - &supports_flags<uint_least16_t>::flags, - &supports_flags<uint_least16_t>::set_flags) + &supports_flags<uint_least16_t>::flags, + &supports_flags<uint_least16_t>::set_flags) .def("has_flags", &supports_flags<uint_least16_t>::has_flags) .def("clear_flags", &supports_flags<uint_least16_t>::clear_flags) .def("add_flags", &supports_flags<uint_least16_t>::add_flags) @@ -97,34 +97,34 @@ void export_post() #endif .add_property("visited_value", - make_getter(&post_t::xdata_t::visited_value), - make_setter(&post_t::xdata_t::visited_value)) + make_getter(&post_t::xdata_t::visited_value), + make_setter(&post_t::xdata_t::visited_value)) .add_property("compound_value", - make_getter(&post_t::xdata_t::compound_value), - make_setter(&post_t::xdata_t::compound_value)) + make_getter(&post_t::xdata_t::compound_value), + make_setter(&post_t::xdata_t::compound_value)) .add_property("total", - make_getter(&post_t::xdata_t::total), - make_setter(&post_t::xdata_t::total)) + make_getter(&post_t::xdata_t::total), + make_setter(&post_t::xdata_t::total)) .add_property("count", - make_getter(&post_t::xdata_t::count), - make_setter(&post_t::xdata_t::count)) + make_getter(&post_t::xdata_t::count), + make_setter(&post_t::xdata_t::count)) .add_property("date", - make_getter(&post_t::xdata_t::date), - make_setter(&post_t::xdata_t::date)) + make_getter(&post_t::xdata_t::date), + make_setter(&post_t::xdata_t::date)) .add_property("datetime", - make_getter(&post_t::xdata_t::datetime), - make_setter(&post_t::xdata_t::datetime)) + make_getter(&post_t::xdata_t::datetime), + make_setter(&post_t::xdata_t::datetime)) .add_property("account", - make_getter(&post_t::xdata_t::account, - return_value_policy<reference_existing_object>()), - make_setter(&post_t::xdata_t::account, - with_custodian_and_ward<1, 2>())) + make_getter(&post_t::xdata_t::account, + return_value_policy<reference_existing_object>()), + make_setter(&post_t::xdata_t::account, + with_custodian_and_ward<1, 2>())) .add_property("sort_values", - make_getter(&post_t::xdata_t::sort_values), - make_setter(&post_t::xdata_t::sort_values)) + make_getter(&post_t::xdata_t::sort_values), + make_setter(&post_t::xdata_t::sort_values)) ; - scope().attr("POST_VIRTUAL") = POST_VIRTUAL; + scope().attr("POST_VIRTUAL") = POST_VIRTUAL; scope().attr("POST_MUST_BALANCE") = POST_MUST_BALANCE; scope().attr("POST_CALCULATED") = POST_CALCULATED; scope().attr("POST_COST_CALCULATED") = POST_COST_CALCULATED; @@ -133,24 +133,24 @@ void export_post() //.def(init<account_t *>()) .add_property("xact", - make_getter(&post_t::xact, - return_internal_reference<>()), - make_setter(&post_t::xact, - with_custodian_and_ward<1, 2>())) + make_getter(&post_t::xact, + return_internal_reference<>()), + make_setter(&post_t::xact, + with_custodian_and_ward<1, 2>())) .add_property("account", - make_getter(&post_t::account, - return_internal_reference<>()), - make_setter(&post_t::account, - with_custodian_and_ward<1, 2>())) + make_getter(&post_t::account, + return_internal_reference<>()), + make_setter(&post_t::account, + with_custodian_and_ward<1, 2>())) .add_property("amount", - make_getter(&post_t::amount), - make_setter(&post_t::amount)) + make_getter(&post_t::amount), + make_setter(&post_t::amount)) .add_property("cost", - make_getter(&post_t::cost), - make_setter(&post_t::cost)) + make_getter(&post_t::cost), + make_setter(&post_t::cost)) .add_property("assigned_amount", - make_getter(&post_t::assigned_amount), - make_setter(&post_t::assigned_amount)) + make_getter(&post_t::assigned_amount), + make_setter(&post_t::assigned_amount)) .def("has_tag", py_has_tag_1s) .def("has_tag", py_has_tag_1m) @@ -171,13 +171,13 @@ void export_post() .def("has_xdata", &post_t::has_xdata) .def("clear_xdata", &post_t::clear_xdata) .def("xdata", py_xdata, - return_internal_reference<>()) + return_internal_reference<>()) .def("add_to_value", &post_t::add_to_value) .def("set_reported_account", &post_t::set_reported_account) .def("reported_account", py_reported_account, - return_internal_reference<>()) + return_internal_reference<>()) ; } diff --git a/src/py_times.cc b/src/py_times.cc index 39b0df7a..c2e0b8f8 100644 --- a/src/py_times.cc +++ b/src/py_times.cc @@ -41,10 +41,10 @@ namespace ledger { using namespace boost::python; -#define MY_PyDateTime_IMPORT \ - PyDateTimeAPI = (PyDateTime_CAPI*) \ - PyCObject_Import(const_cast<char *>("datetime"), \ - const_cast<char *>("datetime_CAPI")) +#define MY_PyDateTime_IMPORT \ + PyDateTimeAPI = (PyDateTime_CAPI*) \ + PyCObject_Import(const_cast<char *>("datetime"), \ + const_cast<char *>("datetime_CAPI")) struct date_to_python { @@ -65,7 +65,7 @@ struct date_from_python } static void construct(PyObject * obj_ptr, - converter::rvalue_from_python_stage1_data * data) + converter::rvalue_from_python_stage1_data * data) { MY_PyDateTime_IMPORT; @@ -113,7 +113,7 @@ struct datetime_from_python } static void construct(PyObject * obj_ptr, - converter::rvalue_from_python_stage1_data * data) + converter::rvalue_from_python_stage1_data * data) { MY_PyDateTime_IMPORT; @@ -139,14 +139,14 @@ struct datetime_from_python datetime_t * moment = new datetime_t(date_t(y, m, d), - datetime_t::time_duration_type(h, min, s, ms)); + datetime_t::time_duration_type(h, min, s, ms)); data->convertible = (void *) moment; } }; typedef register_python_conversion<datetime_t, - datetime_to_python, datetime_from_python> + datetime_to_python, datetime_from_python> datetime_python_conversion; @@ -189,7 +189,7 @@ struct duration_from_python } static void construct(PyObject* obj_ptr, - python::converter::rvalue_from_python_stage1_data * data) + python::converter::rvalue_from_python_stage1_data * data) { PyDateTime_Delta const* pydelta = reinterpret_cast<PyDateTime_Delta*>(obj_ptr); @@ -202,8 +202,8 @@ struct duration_from_python // Create time duration object posix_time::time_duration duration = (posix_time::hours(24) * days + - posix_time::seconds(pydelta->seconds) + - posix_time::microseconds(pydelta->microseconds)); + posix_time::seconds(pydelta->seconds) + + posix_time::microseconds(pydelta->microseconds)); if (is_negative) duration = duration.invert_sign(); @@ -218,7 +218,7 @@ struct duration_from_python }; typedef register_python_conversion<time_duration_t, - duration_to_python, duration_from_python> + duration_to_python, duration_from_python> duration_python_conversion; @@ -240,7 +240,7 @@ void export_times() register_optional_to_python<date_t>(); scope().attr("parse_datetime") = &py_parse_datetime; - scope().attr("parse_date") = &py_parse_date; + scope().attr("parse_date") = &py_parse_date; scope().attr("times_initialize") = ×_initialize; scope().attr("times_shutdown") = ×_shutdown; diff --git a/src/py_utils.cc b/src/py_utils.cc index 952416cc..c513def4 100644 --- a/src/py_utils.cc +++ b/src/py_utils.cc @@ -59,7 +59,7 @@ struct bool_from_python } static void construct(PyObject* obj_ptr, - converter::rvalue_from_python_stage1_data* data) + converter::rvalue_from_python_stage1_data* data) { void * storage = ((converter::rvalue_from_python_storage<bool>*) data)->storage.bytes; @@ -89,19 +89,19 @@ struct string_from_python static void* convertible(PyObject* obj_ptr) { if (!PyUnicode_Check(obj_ptr) && - !PyString_Check(obj_ptr)) return 0; + !PyString_Check(obj_ptr)) return 0; return obj_ptr; } static void construct(PyObject* obj_ptr, - converter::rvalue_from_python_stage1_data* data) + converter::rvalue_from_python_stage1_data* data) { if (PyString_Check(obj_ptr)) { const char* value = PyString_AsString(obj_ptr); if (value == 0) throw_error_already_set(); void* storage = - reinterpret_cast<converter::rvalue_from_python_storage<string> *> - (data)->storage.bytes; + reinterpret_cast<converter::rvalue_from_python_storage<string> *> + (data)->storage.bytes; new (storage) string(value); data->convertible = storage; } else { @@ -112,18 +112,18 @@ struct string_from_python string str; if (sizeof(Py_UNICODE) == 2) // UTF-16 - utf8::unchecked::utf16to8(value, value + size, std::back_inserter(str)); + utf8::unchecked::utf16to8(value, value + size, std::back_inserter(str)); else if (sizeof(Py_UNICODE) == 4) // UTF-32 - utf8::unchecked::utf32to8(value, value + size, std::back_inserter(str)); + utf8::unchecked::utf32to8(value, value + size, std::back_inserter(str)); #if !defined(NO_ASSERTS) else - assert(! "Py_UNICODE has an unexpected size"); + assert(! "Py_UNICODE has an unexpected size"); #endif if (value == 0) throw_error_already_set(); void* storage = - reinterpret_cast<converter::rvalue_from_python_storage<string> *> - (data)->storage.bytes; + reinterpret_cast<converter::rvalue_from_python_storage<string> *> + (data)->storage.bytes; new (storage) string(str); data->convertible = storage; } @@ -151,7 +151,7 @@ struct istream_from_python } static void construct(PyObject* obj_ptr, - converter::rvalue_from_python_stage1_data* data) + converter::rvalue_from_python_stage1_data* data) { void* storage = reinterpret_cast<converter::rvalue_from_python_storage<pyifstream> *> @@ -162,7 +162,7 @@ struct istream_from_python }; typedef register_python_conversion<std::istream, - istream_to_python, istream_from_python> + istream_to_python, istream_from_python> istream_python_conversion; @@ -183,7 +183,7 @@ struct ostream_from_python } static void construct(PyObject* obj_ptr, - converter::rvalue_from_python_stage1_data* data) + converter::rvalue_from_python_stage1_data* data) { void* storage = reinterpret_cast<converter::rvalue_from_python_storage<pyofstream> *> @@ -194,7 +194,7 @@ struct ostream_from_python }; typedef register_python_conversion<std::ostream, - ostream_to_python, ostream_from_python> + ostream_to_python, ostream_from_python> ostream_python_conversion; @@ -205,8 +205,8 @@ void export_utils() .def(init<uint_least8_t>()) .add_property("flags", - &supports_flags<uint_least8_t>::flags, - &supports_flags<uint_least8_t>::set_flags) + &supports_flags<uint_least8_t>::flags, + &supports_flags<uint_least8_t>::set_flags) .def("has_flags", &supports_flags<uint_least8_t>::has_flags) .def("clear_flags", &supports_flags<uint_least8_t>::clear_flags) .def("add_flags", &supports_flags<uint_least8_t>::add_flags) @@ -218,8 +218,8 @@ void export_utils() .def(init<uint_least16_t>()) .add_property("flags", - &supports_flags<uint_least16_t>::flags, - &supports_flags<uint_least16_t>::set_flags) + &supports_flags<uint_least16_t>::flags, + &supports_flags<uint_least16_t>::set_flags) .def("has_flags", &supports_flags<uint_least16_t>::has_flags) .def("clear_flags", &supports_flags<uint_least16_t>::clear_flags) .def("add_flags", &supports_flags<uint_least16_t>::add_flags) @@ -237,10 +237,10 @@ void export_utils() #endif class_< delegates_flags<uint_least16_t>, - boost::noncopyable > ("DelegatesFlags16", no_init) + boost::noncopyable > ("DelegatesFlags16", no_init) .add_property("flags", - &delegates_flags<uint_least16_t>::flags, - &delegates_flags<uint_least16_t>::set_flags) + &delegates_flags<uint_least16_t>::flags, + &delegates_flags<uint_least16_t>::set_flags) .def("has_flags", &delegates_flags<uint_least16_t>::has_flags) .def("clear_flags", &delegates_flags<uint_least16_t>::clear_flags) .def("add_flags", &delegates_flags<uint_least16_t>::add_flags) diff --git a/src/py_value.cc b/src/py_value.cc index 46fa94c3..f8f36453 100644 --- a/src/py_value.cc +++ b/src/py_value.cc @@ -42,7 +42,7 @@ using namespace boost::python; BOOST_PYTHON_MEMBER_FUNCTION_OVERLOADS(value_overloads, value, 0, 2) BOOST_PYTHON_MEMBER_FUNCTION_OVERLOADS(exchange_commodities_overloads, - exchange_commodities, 1, 2) + exchange_commodities, 1, 2) BOOST_PYTHON_MEMBER_FUNCTION_OVERLOADS(set_string_overloads, set_string, 0, 2) namespace { @@ -51,12 +51,12 @@ namespace { return value.value(CURRENT_TIME()); } boost::optional<value_t> py_value_1(const value_t& value, - commodity_t& in_terms_of) { + commodity_t& in_terms_of) { return value.value(CURRENT_TIME(), in_terms_of); } boost::optional<value_t> py_value_2(const value_t& value, - commodity_t& in_terms_of, - datetime_t& moment) { + commodity_t& in_terms_of, + datetime_t& moment) { return value.value(moment, in_terms_of); } @@ -110,9 +110,9 @@ namespace { } // unnamed namespace -#define EXC_TRANSLATOR(type) \ - void exc_translate_ ## type(const type& err) { \ - PyErr_SetString(PyExc_ArithmeticError, err.what()); \ +#define EXC_TRANSLATOR(type) \ + void exc_translate_ ## type(const type& err) { \ + PyErr_SetString(PyExc_ArithmeticError, err.what()); \ } EXC_TRANSLATOR(value_error) @@ -120,16 +120,16 @@ EXC_TRANSLATOR(value_error) void export_value() { enum_< value_t::type_t >("ValueType") - .value("Void", value_t::VOID) - .value("Boolean", value_t::BOOLEAN) - .value("DateTime", value_t::DATETIME) - .value("Date", value_t::DATE) - .value("Integer", value_t::INTEGER) - .value("Amount", value_t::AMOUNT) - .value("Balance", value_t::BALANCE) - .value("String", value_t::STRING) - .value("Sequence", value_t::SEQUENCE) - .value("Scope", value_t::SCOPE) + .value("Void", value_t::VOID) + .value("Boolean", value_t::BOOLEAN) + .value("DateTime", value_t::DATETIME) + .value("Date", value_t::DATE) + .value("Integer", value_t::INTEGER) + .value("Amount", value_t::AMOUNT) + .value("Balance", value_t::BALANCE) + .value("String", value_t::STRING) + .value("Sequence", value_t::SEQUENCE) + .value("Scope", value_t::SCOPE) ; class_< value_t > ("Value") @@ -214,9 +214,9 @@ void export_value() .def(self -= other<amount_t>()) .def(self -= other<balance_t>()) - .def(self - self) - .def(self - long()) - .def(long() - self) + .def(self - self) + .def(self - long()) + .def(long() - self) .def(self - other<amount_t>()) .def(other<amount_t>() - self) .def(self - other<balance_t>()) @@ -225,8 +225,8 @@ void export_value() .def(self *= long()) .def(self *= other<amount_t>()) - .def(self * self) - .def(self * long()) + .def(self * self) + .def(self * long()) .def(long() * self) .def(self * other<amount_t>()) .def(other<amount_t>() * self) @@ -235,9 +235,9 @@ void export_value() .def(self /= long()) .def(self /= other<amount_t>()) - .def(self / self) - .def(self / long()) - .def(long() / self) + .def(self / self) + .def(self / long()) + .def(long() / self) .def(self / other<amount_t>()) .def(other<amount_t>() / self) @@ -269,7 +269,7 @@ void export_value() .def("value", &value_t::value, value_overloads()) .def("price", &value_t::price) .def("exchange_commodities", &value_t::exchange_commodities, - exchange_commodities_overloads()) + exchange_commodities_overloads()) .def("__nonzero__", &value_t::is_nonzero) .def("is_nonzero", &value_t::is_nonzero) @@ -333,8 +333,8 @@ void export_value() .def("annotate", &value_t::annotate) .def("has_annotation", &value_t::has_annotation) .add_property("annotation", - make_function(py_value_annotation, - return_internal_reference<>())) + make_function(py_value_annotation, + return_internal_reference<>())) .def("strip_annotations", py_strip_annotations_0) .def("strip_annotations", py_strip_annotations_1) @@ -352,13 +352,17 @@ void export_value() .def("basetype", py_base_type) ; +#if 0 + // jww (2010-06-10): This is not working since I switched sequence_t to + // ptr_deque<value_t>. class_< value_t::sequence_t > ("ValueSequence") - .def(vector_indexing_suite< value_t::sequence_t >()); + .def(vector_indexing_suite< value_t::sequence_t, true >()); ; +#endif scope().attr("NULL_VALUE") = NULL_VALUE; scope().attr("string_value") = &string_value; - scope().attr("mask_value") = &mask_value; + scope().attr("mask_value") = &mask_value; scope().attr("value_context") = &value_context; register_optional_to_python<value_t>(); diff --git a/src/py_xact.cc b/src/py_xact.cc index 6553a67f..5ab0d90d 100644 --- a/src/py_xact.cc +++ b/src/py_xact.cc @@ -84,14 +84,14 @@ void export_xact() { class_< xact_base_t, bases<item_t> > ("TransactionBase") .add_property("journal", - make_getter(&xact_base_t::journal, - return_internal_reference<>()), - make_setter(&xact_base_t::journal, - with_custodian_and_ward<1, 2>())) + make_getter(&xact_base_t::journal, + return_internal_reference<>()), + make_setter(&xact_base_t::journal, + with_custodian_and_ward<1, 2>())) .def("__len__", posts_len) .def("__getitem__", posts_getitem, - return_internal_reference<>()) + return_internal_reference<>()) .def("add_post", &xact_base_t::add_post, with_custodian_and_ward<1, 2>()) .def("remove_post", &xact_base_t::add_post) @@ -99,20 +99,20 @@ void export_xact() .def("finalize", &xact_base_t::finalize) .def("__iter__", python::range<return_internal_reference<> > - (&xact_t::posts_begin, &xact_t::posts_end)) + (&xact_t::posts_begin, &xact_t::posts_end)) .def("posts", python::range<return_internal_reference<> > - (&xact_t::posts_begin, &xact_t::posts_end)) + (&xact_t::posts_begin, &xact_t::posts_end)) .def("valid", &xact_base_t::valid) ; class_< xact_t, bases<xact_base_t> > ("Transaction") .add_property("code", - make_getter(&xact_t::code), - make_setter(&xact_t::code)) + make_getter(&xact_t::code), + make_setter(&xact_t::code)) .add_property("payee", - make_getter(&xact_t::payee), - make_setter(&xact_t::payee)) + make_getter(&xact_t::payee), + make_setter(&xact_t::payee)) .def("add_post", &xact_t::add_post, with_custodian_and_ward<1, 2>()) @@ -132,8 +132,8 @@ void export_xact() .def(init<predicate_t>()) .add_property("predicate", - make_getter(&auto_xact_t::predicate), - make_setter(&auto_xact_t::predicate)) + make_getter(&auto_xact_t::predicate), + make_setter(&auto_xact_t::predicate)) .def("extend_xact", &auto_xact_t::extend_xact) ; @@ -142,11 +142,11 @@ void export_xact() .def(init<string>()) .add_property("period", - make_getter(&period_xact_t::period), - make_setter(&period_xact_t::period)) + make_getter(&period_xact_t::period), + make_setter(&period_xact_t::period)) .add_property("period_string", - make_getter(&period_xact_t::period_string), - make_setter(&period_xact_t::period_string)) + make_getter(&period_xact_t::period_string), + make_setter(&period_xact_t::period_string)) ; } diff --git a/src/pyfstream.h b/src/pyfstream.h index 02e4d240..37978ff4 100644 --- a/src/pyfstream.h +++ b/src/pyfstream.h @@ -59,7 +59,7 @@ protected: z[0] = static_cast<char>(c); z[1] = '\0'; if (PyFile_WriteString(z, reinterpret_cast<PyObject *>(fo)) < 0) { - return EOF; + return EOF; } } return c; @@ -124,8 +124,8 @@ public: TRACE_CTOR(pyinbuf, "PyFileObject *"); setg (buffer+pbSize, // beginning of putback area - buffer+pbSize, // read position - buffer+pbSize); // end position + buffer+pbSize, // read position + buffer+pbSize); // end position } ~pyinbuf() throw() { TRACE_DTOR(pyinbuf); @@ -157,7 +157,7 @@ protected: * the putback area */ memmove (buffer+(pbSize-numPutback), gptr()-numPutback, - numPutback); + numPutback); // read at most bufSize new characters PyObject *line = PyFile_GetLine(reinterpret_cast<PyObject *>(fo), bufSize); @@ -174,8 +174,8 @@ protected: // reset buffer pointers setg (buffer+(pbSize-numPutback), // beginning of putback area - buffer+pbSize, // read position - buffer+pbSize+num); // end of buffer + buffer+pbSize, // read position + buffer+pbSize+num); // end of buffer // return next character return traits_type::to_int_type(*gptr()); diff --git a/src/pyinterp.cc b/src/pyinterp.cc index 1330fc5c..76fc0561 100644 --- a/src/pyinterp.cc +++ b/src/pyinterp.cc @@ -80,10 +80,10 @@ struct python_run object result; python_run(python_interpreter_t * intepreter, - const string& str, int input_mode) + const string& str, int input_mode) : result(handle<>(borrowed(PyRun_String(str.c_str(), input_mode, - intepreter->main_nspace.ptr(), - intepreter->main_nspace.ptr())))) {} + intepreter->main_nspace.ptr(), + intepreter->main_nspace.ptr())))) {} operator object() { return result; } @@ -104,12 +104,12 @@ void python_interpreter_t::initialize() object main_module = python::import("__main__"); if (! main_module) throw_(std::runtime_error, - _("Python failed to initialize (couldn't find __main__)")); + _("Python failed to initialize (couldn't find __main__)")); main_nspace = extract<dict>(main_module.attr("__dict__")); if (! main_nspace) throw_(std::runtime_error, - _("Python failed to initialize (couldn't find __dict__)")); + _("Python failed to initialize (couldn't find __dict__)")); python::detail::init_module("ledger", &initialize_for_python); @@ -142,17 +142,17 @@ void python_interpreter_t::hack_system_paths() if (exists(pathname / "ledger" / "__init__.py")) { if (python::object module_ledger = python::import("ledger")) { - DEBUG("python.interp", - "Setting ledger.__path__ = " << (pathname / "ledger")); + DEBUG("python.interp", + "Setting ledger.__path__ = " << (pathname / "ledger")); - python::object ledger_dict = module_ledger.attr("__dict__"); - python::list temp_list; - temp_list.append((pathname / "ledger").string()); + python::object ledger_dict = module_ledger.attr("__dict__"); + python::list temp_list; + temp_list.append((pathname / "ledger").string()); - ledger_dict["__path__"] = temp_list; + ledger_dict["__path__"] = temp_list; } else { - throw_(std::runtime_error, - _("Python failed to initialize (couldn't find ledger)")); + throw_(std::runtime_error, + _("Python failed to initialize (couldn't find ledger)")); } #if defined(DEBUG_ON) path_initialized = true; @@ -163,7 +163,7 @@ void python_interpreter_t::hack_system_paths() #if defined(DEBUG_ON) if (! path_initialized) DEBUG("python.init", - "Ledger failed to find 'ledger/__init__.py' on the PYTHONPATH"); + "Ledger failed to find 'ledger/__init__.py' on the PYTHONPATH"); #endif } @@ -176,7 +176,7 @@ object python_interpreter_t::import_into_main(const string& str) object mod = python::import(str.c_str()); if (! mod) throw_(std::runtime_error, - _("Failed to import Python module %1") << str); + _("Failed to import Python module %1") << str); // Import all top-level entries directly into the main namespace main_nspace.update(mod.attr("__dict__")); @@ -217,7 +217,7 @@ object python_interpreter_t::import_option(const string& str) object python_interpreter_t::eval(std::istream& in, py_eval_mode_t mode) { - bool first = true; + bool first = true; string buffer; buffer.reserve(4096); @@ -328,12 +328,12 @@ value_t python_interpreter_t::server_command(call_scope_t& args) server_module = python::import("ledger.server"); if (! server_module) throw_(std::runtime_error, - _("Could not import ledger.server; please check your PYTHONPATH")); + _("Could not import ledger.server; please check your PYTHONPATH")); } catch (const error_already_set&) { PyErr_Print(); throw_(std::runtime_error, - _("Could not import ledger.server; please check your PYTHONPATH")); + _("Could not import ledger.server; please check your PYTHONPATH")); } if (python::object main_function = server_module.attr("main")) { @@ -344,12 +344,12 @@ value_t python_interpreter_t::server_command(call_scope_t& args) catch (const error_already_set&) { PyErr_Print(); throw_(std::runtime_error, - _("Error while invoking ledger.server's main() function")); + _("Error while invoking ledger.server's main() function")); } return true; } else { throw_(std::runtime_error, - _("The ledger.server module is missing its main() function!")); + _("The ledger.server module is missing its main() function!")); } return false; @@ -367,7 +367,7 @@ python_interpreter_t::lookup_option(const char * p) } expr_t::ptr_op_t python_interpreter_t::lookup(const symbol_t::kind_t kind, - const string& name) + const string& name) { // Give our superclass first dibs on symbol definitions if (expr_t::ptr_op_t op = session_t::lookup(kind, name)) @@ -382,7 +382,7 @@ expr_t::ptr_op_t python_interpreter_t::lookup(const symbol_t::kind_t kind, DEBUG("python.interp", "Python lookup: " << name); if (python::object obj = main_nspace.get(name.c_str())) - return WRAP_FUNCTOR(functor_t(obj, name)); + return WRAP_FUNCTOR(functor_t(obj, name)); } break; @@ -396,12 +396,12 @@ expr_t::ptr_op_t python_interpreter_t::lookup(const symbol_t::kind_t kind, switch (*p) { case 'p': if (is_eq(p, "python")) - return MAKE_FUNCTOR(python_interpreter_t::python_command); + return MAKE_FUNCTOR(python_interpreter_t::python_command); break; case 's': if (is_eq(p, "server")) - return MAKE_FUNCTOR(python_interpreter_t::server_command); + return MAKE_FUNCTOR(python_interpreter_t::server_command); break; } } @@ -419,21 +419,21 @@ namespace { if (value.is_scope()) { const scope_t * scope = value.as_scope(); if (const post_t * post = dynamic_cast<const post_t *>(scope)) - lst.append(ptr(post)); + lst.append(ptr(post)); else if (const xact_t * xact = dynamic_cast<const xact_t *>(scope)) - lst.append(ptr(xact)); + lst.append(ptr(xact)); else if (const account_t * account = - dynamic_cast<const account_t *>(scope)) - lst.append(ptr(account)); + dynamic_cast<const account_t *>(scope)) + lst.append(ptr(account)); else if (const period_xact_t * period_xact = - dynamic_cast<const period_xact_t *>(scope)) - lst.append(ptr(period_xact)); + dynamic_cast<const period_xact_t *>(scope)) + lst.append(ptr(period_xact)); else if (const auto_xact_t * auto_xact = - dynamic_cast<const auto_xact_t *>(scope)) - lst.append(ptr(auto_xact)); + dynamic_cast<const auto_xact_t *>(scope)) + lst.append(ptr(auto_xact)); else - throw_(std::logic_error, - _("Cannot downcast scoped object to specific type")); + throw_(std::logic_error, + _("Cannot downcast scoped object to specific type")); } else { lst.append(value); } @@ -449,7 +449,7 @@ value_t python_interpreter_t::functor_t::operator()(call_scope_t& args) extract<value_t> val(func); std::signal(SIGINT, sigint_handler); if (val.check()) - return val(); + return val(); return NULL_VALUE; } else if (args.size() > 0) { @@ -457,31 +457,31 @@ value_t python_interpreter_t::functor_t::operator()(call_scope_t& args) // jww (2009-11-05): What about a single argument which is a sequence, // rather than a sequence of arguments? if (args.value().is_sequence()) - foreach (const value_t& value, args.value().as_sequence()) - append_value(arglist, value); + foreach (const value_t& value, args.value().as_sequence()) + append_value(arglist, value); else - append_value(arglist, args.value()); + append_value(arglist, args.value()); if (PyObject * val = - PyObject_CallObject(func.ptr(), python::tuple(arglist).ptr())) { - extract<value_t> xval(val); - value_t result; - if (xval.check()) { - result = xval(); - Py_DECREF(val); - } else { - Py_DECREF(val); - throw_(calc_error, - _("Could not evaluate Python variable '%1'") << name); - } - std::signal(SIGINT, sigint_handler); - return result; + PyObject_CallObject(func.ptr(), python::tuple(arglist).ptr())) { + extract<value_t> xval(val); + value_t result; + if (xval.check()) { + result = xval(); + Py_DECREF(val); + } else { + Py_DECREF(val); + throw_(calc_error, + _("Could not evaluate Python variable '%1'") << name); + } + std::signal(SIGINT, sigint_handler); + return result; } else if (PyErr_Occurred()) { - PyErr_Print(); - throw_(calc_error, _("Failed call to Python function '%1'") << name); + PyErr_Print(); + throw_(calc_error, _("Failed call to Python function '%1'") << name); } else { - assert(false); + assert(false); } } else { diff --git a/src/pyinterp.h b/src/pyinterp.h index e3a091ad..3d747d5c 100644 --- a/src/pyinterp.h +++ b/src/pyinterp.h @@ -69,11 +69,11 @@ public: }; python::object eval(std::istream& in, - py_eval_mode_t mode = PY_EVAL_EXPR); + py_eval_mode_t mode = PY_EVAL_EXPR); python::object eval(const string& str, - py_eval_mode_t mode = PY_EVAL_EXPR); + py_eval_mode_t mode = PY_EVAL_EXPR); python::object eval(const char * c_str, - py_eval_mode_t mode = PY_EVAL_EXPR) { + py_eval_mode_t mode = PY_EVAL_EXPR) { string str(c_str); return eval(str, mode); } @@ -107,7 +107,7 @@ public: option_t<python_interpreter_t> * lookup_option(const char * p); virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name); + const string& name); OPTION_(python_interpreter_t, import_, DO_(scope) { interactive_t args(scope, "ss"); diff --git a/src/pyutils.h b/src/pyutils.h index e0f77003..efb1b858 100644 --- a/src/pyutils.h +++ b/src/pyutils.h @@ -59,8 +59,8 @@ struct register_optional_to_python : public boost::noncopyable static PyObject * convert(const boost::optional<T>& value) { return boost::python::incref - (value ? boost::python::to_python_value<T>()(*value) : - boost::python::detail::none()); + (value ? boost::python::to_python_value<T>()(*value) : + boost::python::detail::none()); } }; @@ -71,30 +71,30 @@ struct register_optional_to_python : public boost::noncopyable using namespace boost::python::converter; if (source == Py_None) - return source; + return source; const registration& converters(registered<T>::converters); if (implicit_rvalue_convertible_from_python(source, converters)) { - rvalue_from_python_stage1_data data = - rvalue_from_python_stage1(source, converters); - return rvalue_from_python_stage2(source, data, converters); + rvalue_from_python_stage1_data data = + rvalue_from_python_stage1(source, converters); + return rvalue_from_python_stage2(source, data, converters); } return NULL; } static void construct(PyObject * source, - boost::python::converter::rvalue_from_python_stage1_data * data) + boost::python::converter::rvalue_from_python_stage1_data * data) { using namespace boost::python::converter; void * const storage = - reinterpret_cast<rvalue_from_python_storage<T> *>(data)->storage.bytes; + reinterpret_cast<rvalue_from_python_storage<T> *>(data)->storage.bytes; - if (data->convertible == source) // == None - new (storage) boost::optional<T>(); // A Boost uninitialized value + if (data->convertible == source) // == None + new (storage) boost::optional<T>(); // A Boost uninitialized value else - new (storage) boost::optional<T>(*reinterpret_cast<T *>(data->convertible)); + new (storage) boost::optional<T>(*reinterpret_cast<T *>(data->convertible)); data->convertible = storage; } diff --git a/src/query.cc b/src/query.cc index 363c6f73..404c101f 100644 --- a/src/query.cc +++ b/src/query.cc @@ -58,17 +58,17 @@ query_t::lexer_t::token_t query_t::lexer_t::next_token() case '"': case '/': { string pat; - char closing = *arg_i; + char closing = *arg_i; bool found_closing = false; for (++arg_i; arg_i != arg_end; ++arg_i) { if (*arg_i == '\\') { - if (++arg_i == arg_end) - throw_(parse_error, _("Unexpected '\\' at end of pattern")); + if (++arg_i == arg_end) + throw_(parse_error, _("Unexpected '\\' at end of pattern")); } else if (*arg_i == closing) { - ++arg_i; - found_closing = true; - break; + ++arg_i; + found_closing = true; + break; } pat.push_back(*arg_i); } @@ -125,11 +125,11 @@ query_t::lexer_t::token_t query_t::lexer_t::next_token() case '\t': case '\n': case '\r': - if (! consume_whitespace) - goto test_ident; - else - ident.push_back(*arg_i); - break; + if (! consume_whitespace) + goto test_ident; + else + ident.push_back(*arg_i); + break; case '(': case ')': case '&': @@ -139,12 +139,12 @@ query_t::lexer_t::token_t query_t::lexer_t::next_token() case '#': case '%': case '=': - if (! consume_next) - goto test_ident; + if (! consume_next) + goto test_ident; // fall through... default: - ident.push_back(*arg_i); - break; + ident.push_back(*arg_i); + break; } } consume_whitespace = false; @@ -251,7 +251,7 @@ query_t::parser_t::parse_query_term(query_t::lexer_t::token_t::kind_t tok_contex node = parse_query_term(tok.kind); if (! node) throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol()); + _("%1 operator not followed by argument") << tok.symbol()); break; case lexer_t::token_t::TERM: @@ -264,30 +264,30 @@ query_t::parser_t::parse_query_term(query_t::lexer_t::token_t::kind_t tok_contex date_interval_t interval(*tok.value); if (interval.start) { - node = new expr_t::op_t(expr_t::op_t::O_GTE); - node->set_left(ident); + node = new expr_t::op_t(expr_t::op_t::O_GTE); + node->set_left(ident); - expr_t::ptr_op_t arg1 = new expr_t::op_t(expr_t::op_t::VALUE); - arg1->set_value(*interval.start); - node->set_right(arg1); + expr_t::ptr_op_t arg1 = new expr_t::op_t(expr_t::op_t::VALUE); + arg1->set_value(*interval.start); + node->set_right(arg1); } if (interval.finish) { - expr_t::ptr_op_t lt = new expr_t::op_t(expr_t::op_t::O_LT); - lt->set_left(ident); - - expr_t::ptr_op_t arg1 = new expr_t::op_t(expr_t::op_t::VALUE); - arg1->set_value(*interval.finish); - lt->set_right(arg1); - - if (node) { - expr_t::ptr_op_t prev(node); - node = new expr_t::op_t(expr_t::op_t::O_AND); - node->set_left(prev); - node->set_right(lt); - } else { - node = lt; - } + expr_t::ptr_op_t lt = new expr_t::op_t(expr_t::op_t::O_LT); + lt->set_left(ident); + + expr_t::ptr_op_t arg1 = new expr_t::op_t(expr_t::op_t::VALUE); + arg1->set_value(*interval.finish); + lt->set_right(arg1); + + if (node) { + expr_t::ptr_op_t prev(node); + node = new expr_t::op_t(expr_t::op_t::O_AND); + node->set_left(prev); + node->set_right(lt); + } else { + node = lt; + } } break; } @@ -308,22 +308,22 @@ query_t::parser_t::parse_query_term(query_t::lexer_t::token_t::kind_t tok_contex tok = lexer.peek_token(); if (tok.kind == lexer_t::token_t::TOK_EQ) { - tok = lexer.next_token(); - tok = lexer.next_token(); - if (tok.kind != lexer_t::token_t::TERM) - throw_(parse_error, - _("Metadata equality operator not followed by term")); - - expr_t::ptr_op_t arg2 = new expr_t::op_t(expr_t::op_t::VALUE); - assert(tok.value); - arg2->set_value(mask_t(*tok.value)); - - node->set_right(expr_t::op_t::new_node - (expr_t::op_t::O_SEQ, - expr_t::op_t::new_node - (expr_t::op_t::O_CONS, arg1, arg2))); + tok = lexer.next_token(); + tok = lexer.next_token(); + if (tok.kind != lexer_t::token_t::TERM) + throw_(parse_error, + _("Metadata equality operator not followed by term")); + + expr_t::ptr_op_t arg2 = new expr_t::op_t(expr_t::op_t::VALUE); + assert(tok.value); + arg2->set_value(mask_t(*tok.value)); + + node->set_right(expr_t::op_t::new_node + (expr_t::op_t::O_SEQ, + expr_t::op_t::new_node + (expr_t::op_t::O_CONS, arg1, arg2))); } else { - node->set_right(arg1); + node->set_right(arg1); } break; } @@ -334,15 +334,15 @@ query_t::parser_t::parse_query_term(query_t::lexer_t::token_t::kind_t tok_contex expr_t::ptr_op_t ident = new expr_t::op_t(expr_t::op_t::IDENT); switch (tok_context) { case lexer_t::token_t::TOK_ACCOUNT: - ident->set_ident("account"); break; + ident->set_ident("account"); break; case lexer_t::token_t::TOK_PAYEE: - ident->set_ident("payee"); break; + ident->set_ident("payee"); break; case lexer_t::token_t::TOK_CODE: - ident->set_ident("code"); break; + ident->set_ident("code"); break; case lexer_t::token_t::TOK_NOTE: - ident->set_ident("note"); break; + ident->set_ident("note"); break; default: - assert(false); break; + assert(false); break; } expr_t::ptr_op_t mask = new expr_t::op_t(expr_t::op_t::VALUE); @@ -382,7 +382,7 @@ query_t::parser_t::parse_unary_expr(lexer_t::token_t::kind_t tok_context) expr_t::ptr_op_t term(parse_query_term(tok_context)); if (! term) throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol()); + _("%1 operator not followed by argument") << tok.symbol()); node = new expr_t::op_t(expr_t::op_t::O_NOT); node->set_left(term); @@ -405,16 +405,16 @@ query_t::parser_t::parse_and_expr(lexer_t::token_t::kind_t tok_context) while (true) { lexer_t::token_t tok = lexer.next_token(); if (tok.kind == lexer_t::token_t::TOK_AND) { - expr_t::ptr_op_t prev(node); - node = new expr_t::op_t(expr_t::op_t::O_AND); - node->set_left(prev); - node->set_right(parse_unary_expr(tok_context)); - if (! node->right()) - throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol()); + expr_t::ptr_op_t prev(node); + node = new expr_t::op_t(expr_t::op_t::O_AND); + node->set_left(prev); + node->set_right(parse_unary_expr(tok_context)); + if (! node->right()) + throw_(parse_error, + _("%1 operator not followed by argument") << tok.symbol()); } else { - lexer.push_token(tok); - break; + lexer.push_token(tok); + break; } } return node; @@ -429,16 +429,16 @@ query_t::parser_t::parse_or_expr(lexer_t::token_t::kind_t tok_context) while (true) { lexer_t::token_t tok = lexer.next_token(); if (tok.kind == lexer_t::token_t::TOK_OR) { - expr_t::ptr_op_t prev(node); - node = new expr_t::op_t(expr_t::op_t::O_OR); - node->set_left(prev); - node->set_right(parse_and_expr(tok_context)); - if (! node->right()) - throw_(parse_error, - _("%1 operator not followed by argument") << tok.symbol()); + expr_t::ptr_op_t prev(node); + node = new expr_t::op_t(expr_t::op_t::O_OR); + node->set_left(prev); + node->set_right(parse_and_expr(tok_context)); + if (! node->right()) + throw_(parse_error, + _("%1 operator not followed by argument") << tok.symbol()); } else { - lexer.push_token(tok); - break; + lexer.push_token(tok); + break; } } return node; diff --git a/src/query.h b/src/query.h index 59adfd72..e3821f19 100644 --- a/src/query.h +++ b/src/query.h @@ -68,107 +68,107 @@ public: struct token_t { enum kind_t { - UNKNOWN, + UNKNOWN, - LPAREN, - RPAREN, + LPAREN, + RPAREN, - TOK_NOT, - TOK_AND, - TOK_OR, - TOK_EQ, + TOK_NOT, + TOK_AND, + TOK_OR, + TOK_EQ, - TOK_DATE, - TOK_CODE, - TOK_PAYEE, - TOK_NOTE, - TOK_ACCOUNT, - TOK_META, - TOK_EXPR, + TOK_DATE, + TOK_CODE, + TOK_PAYEE, + TOK_NOTE, + TOK_ACCOUNT, + TOK_META, + TOK_EXPR, - TERM, + TERM, - END_REACHED + END_REACHED } kind; optional<string> value; explicit token_t(kind_t _kind = UNKNOWN, - const optional<string>& _value = none) - : kind(_kind), value(_value) { - TRACE_CTOR(query_t::lexer_t::token_t, ""); + const optional<string>& _value = none) + : kind(_kind), value(_value) { + TRACE_CTOR(query_t::lexer_t::token_t, ""); } token_t(const token_t& tok) - : kind(tok.kind), value(tok.value) { - TRACE_CTOR(query_t::lexer_t::token_t, "copy"); + : kind(tok.kind), value(tok.value) { + TRACE_CTOR(query_t::lexer_t::token_t, "copy"); } ~token_t() throw() { - TRACE_DTOR(query_t::lexer_t::token_t); + TRACE_DTOR(query_t::lexer_t::token_t); } token_t& operator=(const token_t& tok) { - if (this != &tok) { - kind = tok.kind; - value = tok.value; - } - return *this; + if (this != &tok) { + kind = tok.kind; + value = tok.value; + } + return *this; } operator bool() const { - return kind != END_REACHED; + return kind != END_REACHED; } string to_string() const { - switch (kind) { - case UNKNOWN: return "UNKNOWN"; - case LPAREN: return "LPAREN"; - case RPAREN: return "RPAREN"; - case TOK_NOT: return "TOK_NOT"; - case TOK_AND: return "TOK_AND"; - case TOK_OR: return "TOK_OR"; - case TOK_EQ: return "TOK_EQ"; - case TOK_DATE: return "TOK_DATE"; - case TOK_CODE: return "TOK_CODE"; - case TOK_PAYEE: return "TOK_PAYEE"; - case TOK_NOTE: return "TOK_NOTE"; - case TOK_ACCOUNT: return "TOK_ACCOUNT"; - case TOK_META: return "TOK_META"; - case TOK_EXPR: return "TOK_EXPR"; - case TERM: return string("TERM(") + *value + ")"; - case END_REACHED: return "END_REACHED"; - } - assert(false); - return empty_string; + switch (kind) { + case UNKNOWN: return "UNKNOWN"; + case LPAREN: return "LPAREN"; + case RPAREN: return "RPAREN"; + case TOK_NOT: return "TOK_NOT"; + case TOK_AND: return "TOK_AND"; + case TOK_OR: return "TOK_OR"; + case TOK_EQ: return "TOK_EQ"; + case TOK_DATE: return "TOK_DATE"; + case TOK_CODE: return "TOK_CODE"; + case TOK_PAYEE: return "TOK_PAYEE"; + case TOK_NOTE: return "TOK_NOTE"; + case TOK_ACCOUNT: return "TOK_ACCOUNT"; + case TOK_META: return "TOK_META"; + case TOK_EXPR: return "TOK_EXPR"; + case TERM: return string("TERM(") + *value + ")"; + case END_REACHED: return "END_REACHED"; + } + assert(false); + return empty_string; } string symbol() const { - switch (kind) { - case LPAREN: return "("; - case RPAREN: return ")"; - case TOK_NOT: return "not"; - case TOK_AND: return "and"; - case TOK_OR: return "or"; - case TOK_EQ: return "="; - case TOK_DATE: return "date"; - case TOK_CODE: return "code"; - case TOK_PAYEE: return "payee"; - case TOK_NOTE: return "note"; - case TOK_ACCOUNT: return "account"; - case TOK_META: return "meta"; - case TOK_EXPR: return "expr"; - - case END_REACHED: return "<EOF>"; - - case TERM: - assert(false); - return "<TERM>"; - - case UNKNOWN: - default: - assert(false); - return "<UNKNOWN>"; - } + switch (kind) { + case LPAREN: return "("; + case RPAREN: return ")"; + case TOK_NOT: return "not"; + case TOK_AND: return "and"; + case TOK_OR: return "or"; + case TOK_EQ: return "="; + case TOK_DATE: return "date"; + case TOK_CODE: return "code"; + case TOK_PAYEE: return "payee"; + case TOK_NOTE: return "note"; + case TOK_ACCOUNT: return "account"; + case TOK_META: return "meta"; + case TOK_EXPR: return "expr"; + + case END_REACHED: return "<EOF>"; + + case TERM: + assert(false); + return "<TERM>"; + + case UNKNOWN: + default: + assert(false); + return "<UNKNOWN>"; + } } void unexpected(); @@ -178,11 +178,11 @@ public: token_t token_cache; lexer_t(value_t::sequence_t::const_iterator _begin, - value_t::sequence_t::const_iterator _end, - bool _multiple_args = true) + value_t::sequence_t::const_iterator _end, + bool _multiple_args = true) : begin(_begin), end(_end), - consume_whitespace(false), consume_next_arg(false), - multiple_args(_multiple_args) + consume_whitespace(false), consume_next_arg(false), + multiple_args(_multiple_args) { TRACE_CTOR(query_t::lexer_t, ""); assert(begin != end); @@ -191,11 +191,11 @@ public: } lexer_t(const lexer_t& lexer) : begin(lexer.begin), end(lexer.end), - arg_i(lexer.arg_i), arg_end(lexer.arg_end), - consume_whitespace(lexer.consume_whitespace), - consume_next_arg(lexer.consume_next_arg), - multiple_args(lexer.multiple_args), - token_cache(lexer.token_cache) + arg_i(lexer.arg_i), arg_end(lexer.arg_end), + consume_whitespace(lexer.consume_whitespace), + consume_next_arg(lexer.consume_next_arg), + multiple_args(lexer.multiple_args), + token_cache(lexer.token_cache) { TRACE_CTOR(query_t::lexer_t, "copy"); } @@ -210,7 +210,7 @@ public: } token_t peek_token() { if (token_cache.kind == token_t::UNKNOWN) - token_cache = next_token(); + token_cache = next_token(); return token_cache; } }; @@ -264,8 +264,8 @@ public: TRACE_CTOR(query_t, "copy"); } query_t(const string& arg, - const keep_details_t& _what_to_keep = keep_details_t(), - bool multiple_args = true) + const keep_details_t& _what_to_keep = keep_details_t(), + bool multiple_args = true) : predicate_t(_what_to_keep) { TRACE_CTOR(query_t, "string, keep_details_t"); if (! arg.empty()) { @@ -274,8 +274,8 @@ public: } } query_t(const value_t& args, - const keep_details_t& _what_to_keep = keep_details_t(), - bool multiple_args = true) + const keep_details_t& _what_to_keep = keep_details_t(), + bool multiple_args = true) : predicate_t(_what_to_keep) { TRACE_CTOR(query_t, "value_t, keep_details_t"); if (! args.empty()) @@ -288,12 +288,12 @@ public: void parse_args(const value_t& args, bool multiple_args = true) { if (! parser) parser = parser_t(args, multiple_args); - ptr = parser->parse(); // expr_t::ptr + ptr = parser->parse(); // expr_t::ptr } void parse_again() { assert(parser); - ptr = parser->parse(); // expr_t::ptr + ptr = parser->parse(); // expr_t::ptr } bool tokens_remaining() { diff --git a/src/quotes.cc b/src/quotes.cc index 4e3ec33e..90c1f3eb 100644 --- a/src/quotes.cc +++ b/src/quotes.cc @@ -40,13 +40,13 @@ namespace ledger { optional<price_point_t> commodity_quote_from_script(commodity_t& commodity, - const optional<commodity_t&>& exchange_commodity) + const optional<commodity_t&>& exchange_commodity) { DEBUG("commodity.download", "downloading quote for symbol " << commodity.symbol()); #if defined(DEBUG_ON) if (exchange_commodity) DEBUG("commodity.download", - " in terms of commodity " << exchange_commodity->symbol()); + " in terms of commodity " << exchange_commodity->symbol()); #endif char buf[256]; @@ -76,29 +76,29 @@ commodity_quote_from_script(commodity_t& commodity, DEBUG("commodity.download", "downloaded quote: " << buf); if (optional<std::pair<commodity_t *, price_point_t> > point = - commodity_pool_t::current_pool->parse_price_directive(buf)) { + commodity_pool_t::current_pool->parse_price_directive(buf)) { if (commodity_pool_t::current_pool->price_db) { #if defined(__GNUG__) && __GNUG__ < 3 - ofstream database(*commodity_pool_t::current_pool->price_db, - ios::out | ios::app); + ofstream database(*commodity_pool_t::current_pool->price_db, + ios::out | ios::app); #else - ofstream database(*commodity_pool_t::current_pool->price_db, - std::ios_base::out | std::ios_base::app); + ofstream database(*commodity_pool_t::current_pool->price_db, + std::ios_base::out | std::ios_base::app); #endif - database << "P " - << format_datetime(point->second.when, FMT_WRITTEN) - << " " << commodity.symbol() - << " " << point->second.price - << std::endl; + database << "P " + << format_datetime(point->second.when, FMT_WRITTEN) + << " " << commodity.symbol() + << " " << point->second.price + << std::endl; } return point->second; } } else { DEBUG("commodity.download", - "Failed to download price for '" << commodity.symbol() << - "' (command: \"getquote " << commodity.symbol() << - " " << (exchange_commodity ? - exchange_commodity->symbol() : "''") << "\")"); + "Failed to download price for '" << commodity.symbol() << + "' (command: \"getquote " << commodity.symbol() << + " " << (exchange_commodity ? + exchange_commodity->symbol() : "''") << "\")"); // Don't try to download this commodity again. commodity.add_flags(COMMODITY_NOMARKET); diff --git a/src/quotes.h b/src/quotes.h index e981fdad..376d8918 100644 --- a/src/quotes.h +++ b/src/quotes.h @@ -46,7 +46,7 @@ namespace ledger { optional<price_point_t> commodity_quote_from_script(commodity_t& commodity, - const optional<commodity_t&>& exchange_commodity); + const optional<commodity_t&>& exchange_commodity); } // namespace ledger diff --git a/src/report.cc b/src/report.cc index bed3ef5c..9656d57a 100644 --- a/src/report.cc +++ b/src/report.cc @@ -76,7 +76,7 @@ void report_t::normalize_options(const string& verb) } item_t::use_effective_date = (HANDLED(effective) && - ! HANDLED(actual_dates)); + ! HANDLED(actual_dates)); commodity_pool_t::current_pool->keep_base = HANDLED(base); commodity_pool_t::current_pool->get_quotes = session.HANDLED(download); @@ -96,7 +96,7 @@ void report_t::normalize_options(const string& verb) set_datetime_format(HANDLER(datetime_format_).str().c_str()); if (HANDLED(start_of_week_)) { if (optional<date_time::weekdays> weekday = - string_to_day_of_week(HANDLER(start_of_week_).str())) + string_to_day_of_week(HANDLER(start_of_week_).str())) start_of_week = *weekday; } @@ -106,24 +106,24 @@ void report_t::normalize_options(const string& verb) if (! HANDLED(meta_width_)) { string::size_type i = HANDLER(meta_).str().find(':'); if (i != string::npos) { - HANDLED(meta_width_).on_with - (string("?normalize"), - lexical_cast<long>(string(HANDLER(meta_).str(), i + 1))); - HANDLED(meta_).on(string("?normalize"), - string(HANDLER(meta_).str(), 0, i)); + HANDLED(meta_width_).on_with + (string("?normalize"), + lexical_cast<long>(string(HANDLER(meta_).str(), i + 1))); + HANDLED(meta_).on(string("?normalize"), + string(HANDLER(meta_).str(), 0, i)); } } if (HANDLED(meta_width_)) { HANDLER(prepend_format_).on - (string("?normalize"), - string("%(justify(truncated(tag(\"") + - HANDLER(meta_).str() + "\"), " + - HANDLED(meta_width_).value.to_string() + " - 1), " + - HANDLED(meta_width_).value.to_string() + "))"); + (string("?normalize"), + string("%(justify(truncated(tag(\"") + + HANDLER(meta_).str() + "\"), " + + HANDLED(meta_width_).value.to_string() + " - 1), " + + HANDLED(meta_width_).value.to_string() + "))"); meta_width = HANDLED(meta_width_).value.to_long(); } else { HANDLER(prepend_format_).on(string("?normalize"), string("%(tag(\"") + - HANDLER(meta_).str() + "\"))"); + HANDLER(meta_).str() + "\"))"); } } if (! HANDLED(prepend_width_)) @@ -137,9 +137,6 @@ void report_t::normalize_options(const string& verb) HANDLER(equity).on_only(string("?normalize")); } - if (verb == "print") - HANDLER(limit_).on(string("?normalize"), "actual"); - if (verb[0] != 'b' && verb[0] != 'r') HANDLER(base).on_only(string("?normalize")); @@ -186,7 +183,7 @@ void report_t::normalize_options(const string& verb) if (HANDLED(exchange_) && HANDLER(exchange_).str().find('=') != string::npos) { value_t(0L).exchange_commodities(HANDLER(exchange_).str(), true, - terminus); + terminus); } long cols = 0; @@ -205,22 +202,22 @@ void report_t::normalize_options(const string& verb) if (! HANDLER(date_width_).specified) HANDLER(date_width_) - .on_with(none, static_cast<long>(format_date(CURRENT_DATE(), - FMT_PRINTED).length())); + .on_with(none, static_cast<long>(format_date(CURRENT_DATE(), + FMT_PRINTED).length())); long date_width = HANDLER(date_width_).value.to_long(); long payee_width = (HANDLER(payee_width_).specified ? - HANDLER(payee_width_).value.to_long() : - int(double(cols) * 0.263157)); + HANDLER(payee_width_).value.to_long() : + int(double(cols) * 0.263157)); long account_width = (HANDLER(account_width_).specified ? - HANDLER(account_width_).value.to_long() : - int(double(cols) * 0.302631)); + HANDLER(account_width_).value.to_long() : + int(double(cols) * 0.302631)); long amount_width = (HANDLER(amount_width_).specified ? - HANDLER(amount_width_).value.to_long() : - int(double(cols) * 0.157894)); + HANDLER(amount_width_).value.to_long() : + int(double(cols) * 0.157894)); long total_width = (HANDLER(total_width_).specified ? - HANDLER(total_width_).value.to_long() : - amount_width); + HANDLER(total_width_).value.to_long() : + amount_width); DEBUG("auto.columns", "date_width = " << date_width); DEBUG("auto.columns", "payee_width = " << payee_width); @@ -229,16 +226,16 @@ void report_t::normalize_options(const string& verb) DEBUG("auto.columns", "total_width = " << total_width); if (! HANDLER(date_width_).specified && - ! HANDLER(payee_width_).specified && - ! HANDLER(account_width_).specified && - ! HANDLER(amount_width_).specified && - ! HANDLER(total_width_).specified) { + ! HANDLER(payee_width_).specified && + ! HANDLER(account_width_).specified && + ! HANDLER(amount_width_).specified && + ! HANDLER(total_width_).specified) { long total = (4 /* the spaces between */ + date_width + payee_width + - account_width + amount_width + total_width); + account_width + amount_width + total_width); if (total > cols) { - DEBUG("auto.columns", "adjusting account down"); - account_width -= total - cols; - DEBUG("auto.columns", "account_width now = " << account_width); + DEBUG("auto.columns", "adjusting account down"); + account_width -= total - cols; + DEBUG("auto.columns", "account_width now = " << account_width); } } @@ -264,7 +261,7 @@ void report_t::parse_query_args(const value_t& args, const string& whence) HANDLER(limit_).on(whence, query.text()); DEBUG("report.predicate", - "Predicate = " << HANDLER(limit_).str()); + "Predicate = " << HANDLER(limit_).str()); } if (query.tokens_remaining()) { @@ -273,7 +270,7 @@ void report_t::parse_query_args(const value_t& args, const string& whence) HANDLER(display_).on(whence, query.text()); DEBUG("report.predicate", - "Display predicate = " << HANDLER(display_).str()); + "Display predicate = " << HANDLER(display_).str()); } } } @@ -282,7 +279,7 @@ namespace { struct posts_flusher { post_handler_ptr handler; - report_t& report; + report_t& report; posts_flusher(post_handler_ptr _handler, report_t& _report) : handler(_handler), report(_report) {} @@ -313,8 +310,6 @@ void report_t::posts_report(post_handler_ptr handler) void report_t::generate_report(post_handler_ptr handler) { - HANDLER(limit_).on(string("#generate"), "actual"); - handler = chain_handlers(handler, *this); generate_posts_iterator walker @@ -340,7 +335,7 @@ namespace { struct accounts_title_printer { acct_handler_ptr handler; - report_t& report; + report_t& report; accounts_title_printer(acct_handler_ptr _handler, report_t& _report) : handler(_handler), report(_report) {} @@ -348,9 +343,9 @@ namespace { void operator()(const value_t& val) { if (! report.HANDLED(no_titles)) { - std::ostringstream buf; - val.print(buf); - handler->title(buf.str()); + std::ostringstream buf; + val.print(buf); + handler->title(buf.str()); } } }; @@ -358,7 +353,7 @@ namespace { struct accounts_flusher { acct_handler_ptr handler; - report_t& report; + report_t& report; accounts_flusher(acct_handler_ptr _handler, report_t& _report) : handler(_handler), report(_report) {} @@ -373,23 +368,23 @@ namespace { scoped_ptr<accounts_iterator> iter; if (! report.HANDLED(sort_)) { - iter.reset(new basic_accounts_iterator(*report.session.journal->master)); + iter.reset(new basic_accounts_iterator(*report.session.journal->master)); } else { - expr_t sort_expr(report.HANDLER(sort_).str()); - sort_expr.set_context(&report); - iter.reset(new sorted_accounts_iterator(*report.session.journal->master, - sort_expr, report.HANDLED(flat))); + expr_t sort_expr(report.HANDLER(sort_).str()); + sort_expr.set_context(&report); + iter.reset(new sorted_accounts_iterator(*report.session.journal->master, + sort_expr, report.HANDLED(flat))); } if (report.HANDLED(display_)) { - DEBUG("report.predicate", - "Display predicate = " << report.HANDLER(display_).str()); - pass_down_accounts(handler, *iter.get(), - predicate_t(report.HANDLER(display_).str(), - report.what_to_keep()), - report); + DEBUG("report.predicate", + "Display predicate = " << report.HANDLER(display_).str()); + pass_down_accounts(handler, *iter.get(), + predicate_t(report.HANDLER(display_).str(), + report.what_to_keep()), + report); } else { - pass_down_accounts(handler, *iter.get()); + pass_down_accounts(handler, *iter.get()); } report.session.journal->clear_xdata(); @@ -401,7 +396,7 @@ void report_t::accounts_report(acct_handler_ptr handler) { post_handler_ptr chain = chain_post_handlers(post_handler_ptr(new ignore_posts), *this, - /* for_accounts_report= */ true); + /* for_accounts_report= */ true); if (HANDLED(group_by_)) { std::auto_ptr<post_splitter> splitter(new post_splitter(chain, *this, HANDLER(group_by_).expr)); @@ -459,12 +454,12 @@ value_t report_t::fn_market(call_scope_t& scope) value_t result; optional<datetime_t> moment = (args.has(1) ? - args.get<datetime_t>(1) : - optional<datetime_t>()); + args.get<datetime_t>(1) : + optional<datetime_t>()); if (args.has(2)) result = args.value_at(0).exchange_commodities(args.get<string>(2), - /* add_prices= */ false, - moment); + /* add_prices= */ false, + moment); else result = args.value_at(0).value(moment); @@ -487,8 +482,8 @@ value_t report_t::fn_get_at(call_scope_t& scope) } else { if (! args.value_at(0).is_sequence()) throw_(std::runtime_error, - _("Attempting to get argument at index %1 from %2") - << args.get<long>(1) << args.value_at(0).label()); + _("Attempting to get argument at index %1 from %2") + << args.get<long>(1) << args.value_at(0).label()); } return args.get<const value_t::sequence_t&>(0)[args.get<long>(1)]; } @@ -589,9 +584,9 @@ value_t report_t::fn_truncated(call_scope_t& scope) { interactive_t args(scope, "v&ll"); return string_value(format_t::truncate - (args.get<string>(0), - args.has(1) && args.get<int>(1) > 0 ? args.get<int>(1) : 0, - args.has(2) ? args.get<int>(2) : 0)); + (args.get<string>(0), + args.has(1) && args.get<int>(1) > 0 ? args.get<int>(1) : 0, + args.has(2) ? args.get<int>(2) : 0)); } value_t report_t::fn_justify(call_scope_t& scope) @@ -613,7 +608,7 @@ value_t report_t::fn_justify(call_scope_t& scope) value_t report_t::fn_quoted(call_scope_t& scope) { - interactive_t args(scope, "v"); + interactive_t args(scope, "v"); std::ostringstream out; out << '"'; @@ -630,7 +625,7 @@ value_t report_t::fn_quoted(call_scope_t& scope) value_t report_t::fn_join(call_scope_t& scope) { - interactive_t args(scope, "s"); + interactive_t args(scope, "s"); std::ostringstream out; foreach (const char ch, args.get<string>(0)) { @@ -647,7 +642,7 @@ value_t report_t::fn_format_date(call_scope_t& scope) interactive_t args(scope, "d&s"); if (args.has(1)) return string_value(format_date(args.get<date_t>(0), FMT_CUSTOM, - args.get<string>(1).c_str())); + args.get<string>(1).c_str())); else return string_value(format_date(args.get<date_t>(0), FMT_PRINTED)); } @@ -659,17 +654,17 @@ value_t report_t::fn_ansify_if(call_scope_t& scope) if (args.has(1)) { string color = args.get<string>(1); std::ostringstream buf; - if (color == "black") buf << "\033[30m"; - else if (color == "red") buf << "\033[31m"; - else if (color == "green") buf << "\033[32m"; - else if (color == "yellow") buf << "\033[33m"; - else if (color == "blue") buf << "\033[34m"; + if (color == "black") buf << "\033[30m"; + else if (color == "red") buf << "\033[31m"; + else if (color == "green") buf << "\033[32m"; + else if (color == "yellow") buf << "\033[33m"; + else if (color == "blue") buf << "\033[34m"; else if (color == "magenta") buf << "\033[35m"; - else if (color == "cyan") buf << "\033[36m"; - else if (color == "white") buf << "\033[37m"; - else if (color == "bold") buf << "\033[1m"; + else if (color == "cyan") buf << "\033[36m"; + else if (color == "white") buf << "\033[37m"; + else if (color == "bold") buf << "\033[1m"; else if (color == "underline") buf << "\033[4m"; - else if (color == "blink") buf << "\033[5m"; + else if (color == "blink") buf << "\033[5m"; buf << args.value_at(0); buf << "\033[0m"; return string_value(buf.str()); @@ -682,7 +677,7 @@ value_t report_t::fn_percent(call_scope_t& scope) { interactive_t args(scope, "aa"); return (amount_t("100.00%") * - (args.get<amount_t>(0) / args.get<amount_t>(1)).number()); + (args.get<amount_t>(0) / args.get<amount_t>(1)).number()); } value_t report_t::fn_price(call_scope_t& scope) @@ -691,6 +686,12 @@ value_t report_t::fn_price(call_scope_t& scope) return args.value_at(0).price(); } +value_t report_t::fn_commodity(call_scope_t& scope) +{ + in_context_t<post_t> env(scope, "v"); + return string_value(env.value_at(0).to_amount().commodity().symbol()); +} + value_t report_t::fn_lot_date(call_scope_t& scope) { interactive_t args(scope, "v"); @@ -992,6 +993,7 @@ option_t<report_t> * report_t::lookup_option(const char * p) OPT(gain); else OPT(group_by_); else OPT(group_title_format_); + else OPT(generated); break; case 'h': OPT(head_); @@ -1045,7 +1047,6 @@ option_t<report_t> * report_t::lookup_option(const char * p) else OPT(payee_width_); else OPT(prepend_format_); else OPT(prepend_width_); - else OPT(print_virtual); break; case 'q': OPT(quantity); @@ -1099,13 +1100,13 @@ option_t<report_t> * report_t::lookup_option(const char * p) } void report_t::define(const symbol_t::kind_t kind, const string& name, - expr_t::ptr_op_t def) + expr_t::ptr_op_t def) { session.define(kind, name, def); } expr_t::ptr_op_t report_t::lookup(const symbol_t::kind_t kind, - const string& name) + const string& name) { if (expr_t::ptr_op_t def = session.lookup(kind, name)) return def; @@ -1119,208 +1120,210 @@ expr_t::ptr_op_t report_t::lookup(const symbol_t::kind_t kind, switch (*p) { case 'd': case 'm': - return MAKE_FUNCTOR(report_t::fn_now); + return MAKE_FUNCTOR(report_t::fn_now); case 'P': - return MAKE_FUNCTOR(report_t::fn_market); + return MAKE_FUNCTOR(report_t::fn_market); case 't': - return MAKE_FUNCTOR(report_t::fn_display_amount); + return MAKE_FUNCTOR(report_t::fn_display_amount); case 'T': - return MAKE_FUNCTOR(report_t::fn_display_total); + return MAKE_FUNCTOR(report_t::fn_display_total); case 'U': - return MAKE_FUNCTOR(report_t::fn_abs); + return MAKE_FUNCTOR(report_t::fn_abs); case 'S': - return MAKE_FUNCTOR(report_t::fn_strip); + return MAKE_FUNCTOR(report_t::fn_strip); case 'i': - throw_(std::runtime_error, - _("The i value expression variable is no longer supported")); + throw_(std::runtime_error, + _("The i value expression variable is no longer supported")); case 'A': - throw_(std::runtime_error, - _("The A value expression variable is no longer supported")); + throw_(std::runtime_error, + _("The A value expression variable is no longer supported")); case 'v': case 'V': - throw_(std::runtime_error, - _("The V and v value expression variables are no longer supported")); + throw_(std::runtime_error, + _("The V and v value expression variables are no longer supported")); case 'I': case 'B': - throw_(std::runtime_error, - _("The I and B value expression variables are no longer supported")); + throw_(std::runtime_error, + _("The I and B value expression variables are no longer supported")); case 'g': case 'G': - throw_(std::runtime_error, - _("The G and g value expression variables are no longer supported")); + throw_(std::runtime_error, + _("The G and g value expression variables are no longer supported")); default: - return NULL; + return NULL; } } switch (*p) { case 'a': if (is_eq(p, "amount_expr")) - return MAKE_FUNCTOR(report_t::fn_amount_expr); + return MAKE_FUNCTOR(report_t::fn_amount_expr); else if (is_eq(p, "ansify_if")) - return MAKE_FUNCTOR(report_t::fn_ansify_if); + return MAKE_FUNCTOR(report_t::fn_ansify_if); else if (is_eq(p, "abs")) - return MAKE_FUNCTOR(report_t::fn_abs); + return MAKE_FUNCTOR(report_t::fn_abs); break; case 'b': if (is_eq(p, "black")) - return WRAP_FUNCTOR(fn_black); + return WRAP_FUNCTOR(fn_black); else if (is_eq(p, "blink")) - return WRAP_FUNCTOR(fn_blink); + return WRAP_FUNCTOR(fn_blink); else if (is_eq(p, "blue")) - return WRAP_FUNCTOR(fn_blue); + return WRAP_FUNCTOR(fn_blue); else if (is_eq(p, "bold")) - return WRAP_FUNCTOR(fn_bold); + return WRAP_FUNCTOR(fn_bold); break; case 'c': if (is_eq(p, "cyan")) - return WRAP_FUNCTOR(fn_cyan); + return WRAP_FUNCTOR(fn_cyan); + else if (is_eq(p, "commodity")) + return MAKE_FUNCTOR(report_t::fn_commodity); break; case 'd': if (is_eq(p, "display_amount")) - return MAKE_FUNCTOR(report_t::fn_display_amount); + return MAKE_FUNCTOR(report_t::fn_display_amount); else if (is_eq(p, "display_total")) - return MAKE_FUNCTOR(report_t::fn_display_total); + return MAKE_FUNCTOR(report_t::fn_display_total); else if (is_eq(p, "date")) - return MAKE_FUNCTOR(report_t::fn_now); + return MAKE_FUNCTOR(report_t::fn_now); break; case 'f': if (is_eq(p, "format_date")) - return MAKE_FUNCTOR(report_t::fn_format_date); + return MAKE_FUNCTOR(report_t::fn_format_date); else if (is_eq(p, "floor")) - return MAKE_FUNCTOR(report_t::fn_floor); + return MAKE_FUNCTOR(report_t::fn_floor); break; case 'g': if (is_eq(p, "get_at")) - return MAKE_FUNCTOR(report_t::fn_get_at); + return MAKE_FUNCTOR(report_t::fn_get_at); else if (is_eq(p, "green")) - return WRAP_FUNCTOR(fn_green); + return WRAP_FUNCTOR(fn_green); break; case 'i': if (is_eq(p, "is_seq")) - return MAKE_FUNCTOR(report_t::fn_is_seq); + return MAKE_FUNCTOR(report_t::fn_is_seq); break; case 'j': if (is_eq(p, "justify")) - return MAKE_FUNCTOR(report_t::fn_justify); + return MAKE_FUNCTOR(report_t::fn_justify); else if (is_eq(p, "join")) - return MAKE_FUNCTOR(report_t::fn_join); + return MAKE_FUNCTOR(report_t::fn_join); break; case 'm': if (is_eq(p, "market")) - return MAKE_FUNCTOR(report_t::fn_market); + return MAKE_FUNCTOR(report_t::fn_market); else if (is_eq(p, "magenta")) - return WRAP_FUNCTOR(fn_magenta); + return WRAP_FUNCTOR(fn_magenta); break; case 'n': if (is_eq(p, "null")) - return WRAP_FUNCTOR(fn_null); + return WRAP_FUNCTOR(fn_null); else if (is_eq(p, "now")) - return MAKE_FUNCTOR(report_t::fn_now); + return MAKE_FUNCTOR(report_t::fn_now); break; case 'o': if (is_eq(p, "options")) - return MAKE_FUNCTOR(report_t::fn_options); + return MAKE_FUNCTOR(report_t::fn_options); break; case 'p': if (is_eq(p, "post")) - return WRAP_FUNCTOR(fn_false); + return WRAP_FUNCTOR(fn_false); else if (is_eq(p, "percent")) - return MAKE_FUNCTOR(report_t::fn_percent); + return MAKE_FUNCTOR(report_t::fn_percent); else if (is_eq(p, "price")) - return MAKE_FUNCTOR(report_t::fn_price); + return MAKE_FUNCTOR(report_t::fn_price); else if (is_eq(p, "print")) - return MAKE_FUNCTOR(report_t::fn_print); + return MAKE_FUNCTOR(report_t::fn_print); break; case 'q': if (is_eq(p, "quoted")) - return MAKE_FUNCTOR(report_t::fn_quoted); + return MAKE_FUNCTOR(report_t::fn_quoted); else if (is_eq(p, "quantity")) - return MAKE_FUNCTOR(report_t::fn_quantity); + return MAKE_FUNCTOR(report_t::fn_quantity); break; case 'r': if (is_eq(p, "rounded")) - return MAKE_FUNCTOR(report_t::fn_rounded); + return MAKE_FUNCTOR(report_t::fn_rounded); else if (is_eq(p, "red")) - return WRAP_FUNCTOR(fn_red); + return WRAP_FUNCTOR(fn_red); break; case 's': if (is_eq(p, "scrub")) - return MAKE_FUNCTOR(report_t::fn_scrub); + return MAKE_FUNCTOR(report_t::fn_scrub); else if (is_eq(p, "strip")) - return MAKE_FUNCTOR(report_t::fn_strip); + return MAKE_FUNCTOR(report_t::fn_strip); break; case 't': if (is_eq(p, "truncated")) - return MAKE_FUNCTOR(report_t::fn_truncated); + return MAKE_FUNCTOR(report_t::fn_truncated); else if (is_eq(p, "total_expr")) - return MAKE_FUNCTOR(report_t::fn_total_expr); + return MAKE_FUNCTOR(report_t::fn_total_expr); else if (is_eq(p, "today")) - return MAKE_FUNCTOR(report_t::fn_today); + return MAKE_FUNCTOR(report_t::fn_today); else if (is_eq(p, "t")) - return MAKE_FUNCTOR(report_t::fn_display_amount); + return MAKE_FUNCTOR(report_t::fn_display_amount); else if (is_eq(p, "trim")) - return MAKE_FUNCTOR(report_t::fn_trim); + return MAKE_FUNCTOR(report_t::fn_trim); else if (is_eq(p, "to_boolean")) - return MAKE_FUNCTOR(report_t::fn_to_boolean); + return MAKE_FUNCTOR(report_t::fn_to_boolean); else if (is_eq(p, "to_int")) - return MAKE_FUNCTOR(report_t::fn_to_int); + return MAKE_FUNCTOR(report_t::fn_to_int); else if (is_eq(p, "to_datetime")) - return MAKE_FUNCTOR(report_t::fn_to_datetime); + return MAKE_FUNCTOR(report_t::fn_to_datetime); else if (is_eq(p, "to_date")) - return MAKE_FUNCTOR(report_t::fn_to_date); + return MAKE_FUNCTOR(report_t::fn_to_date); else if (is_eq(p, "to_amount")) - return MAKE_FUNCTOR(report_t::fn_to_amount); + return MAKE_FUNCTOR(report_t::fn_to_amount); else if (is_eq(p, "to_balance")) - return MAKE_FUNCTOR(report_t::fn_to_balance); + return MAKE_FUNCTOR(report_t::fn_to_balance); else if (is_eq(p, "to_string")) - return MAKE_FUNCTOR(report_t::fn_to_string); + return MAKE_FUNCTOR(report_t::fn_to_string); else if (is_eq(p, "to_mask")) - return MAKE_FUNCTOR(report_t::fn_to_mask); + return MAKE_FUNCTOR(report_t::fn_to_mask); else if (is_eq(p, "to_sequence")) - return MAKE_FUNCTOR(report_t::fn_to_sequence); + return MAKE_FUNCTOR(report_t::fn_to_sequence); break; case 'T': if (is_eq(p, "T")) - return MAKE_FUNCTOR(report_t::fn_display_total); + return MAKE_FUNCTOR(report_t::fn_display_total); break; case 'u': if (is_eq(p, "underline")) - return WRAP_FUNCTOR(fn_underline); + return WRAP_FUNCTOR(fn_underline); else if (is_eq(p, "unrounded")) - return MAKE_FUNCTOR(report_t::fn_unrounded); + return MAKE_FUNCTOR(report_t::fn_unrounded); break; case 'v': if (is_eq(p, "value_date")) - return MAKE_FUNCTOR(report_t::fn_now); + return MAKE_FUNCTOR(report_t::fn_now); break; case 'w': if (is_eq(p, "white")) - return WRAP_FUNCTOR(fn_white); + return WRAP_FUNCTOR(fn_white); break; case 'y': if (is_eq(p, "yellow")) - return WRAP_FUNCTOR(fn_yellow); + return WRAP_FUNCTOR(fn_yellow); break; } @@ -1338,135 +1341,135 @@ expr_t::ptr_op_t report_t::lookup(const symbol_t::kind_t kind, switch (*p) { case 'a': if (is_eq(p, "accounts")) { - return WRAP_FUNCTOR(reporter<>(new report_accounts(*this), *this, - "#accounts")); + return WRAP_FUNCTOR(reporter<>(new report_accounts(*this), *this, + "#accounts")); } break; case 'b': if (*(p + 1) == '\0' || is_eq(p, "bal") || is_eq(p, "balance")) { - return expr_t::op_t::wrap_functor - (reporter<account_t, acct_handler_ptr, &report_t::accounts_report> - (new format_accounts(*this, report_format(HANDLER(balance_format_)), - maybe_format(HANDLER(prepend_format_)), - HANDLER(prepend_width_).value.to_long()), - *this, "#balance")); + return expr_t::op_t::wrap_functor + (reporter<account_t, acct_handler_ptr, &report_t::accounts_report> + (new format_accounts(*this, report_format(HANDLER(balance_format_)), + maybe_format(HANDLER(prepend_format_)), + HANDLER(prepend_width_).value.to_long()), + *this, "#balance")); } else if (is_eq(p, "budget")) { - HANDLER(amount_).set_expr(string("#budget"), "(amount, 0)"); - - budget_flags |= BUDGET_WRAP_VALUES; - if (! (budget_flags & ~BUDGET_WRAP_VALUES)) - budget_flags |= BUDGET_BUDGETED; - - return expr_t::op_t::wrap_functor - (reporter<account_t, acct_handler_ptr, &report_t::accounts_report> - (new format_accounts(*this, report_format(HANDLER(budget_format_)), - maybe_format(HANDLER(prepend_format_)), - HANDLER(prepend_width_).value.to_long()), - *this, "#budget")); + HANDLER(amount_).set_expr(string("#budget"), "(amount, 0)"); + + budget_flags |= BUDGET_WRAP_VALUES; + if (! (budget_flags & ~BUDGET_WRAP_VALUES)) + budget_flags |= BUDGET_BUDGETED; + + return expr_t::op_t::wrap_functor + (reporter<account_t, acct_handler_ptr, &report_t::accounts_report> + (new format_accounts(*this, report_format(HANDLER(budget_format_)), + maybe_format(HANDLER(prepend_format_)), + HANDLER(prepend_width_).value.to_long()), + *this, "#budget")); } break; case 'c': if (is_eq(p, "csv")) { - return WRAP_FUNCTOR - (reporter<> - (new format_posts(*this, report_format(HANDLER(csv_format_)), - maybe_format(HANDLER(prepend_format_)), - HANDLER(prepend_width_).value.to_long()), - *this, "#csv")); + return WRAP_FUNCTOR + (reporter<> + (new format_posts(*this, report_format(HANDLER(csv_format_)), + maybe_format(HANDLER(prepend_format_)), + HANDLER(prepend_width_).value.to_long()), + *this, "#csv")); } else if (is_eq(p, "cleared")) { - HANDLER(amount_).set_expr(string("#cleared"), - "(amount, cleared ? amount : 0)"); - return expr_t::op_t::wrap_functor - (reporter<account_t, acct_handler_ptr, &report_t::accounts_report> - (new format_accounts(*this, report_format(HANDLER(cleared_format_)), - maybe_format(HANDLER(prepend_format_)), - HANDLER(prepend_width_).value.to_long()), - *this, "#cleared")); + HANDLER(amount_).set_expr(string("#cleared"), + "(amount, cleared ? amount : 0)"); + return expr_t::op_t::wrap_functor + (reporter<account_t, acct_handler_ptr, &report_t::accounts_report> + (new format_accounts(*this, report_format(HANDLER(cleared_format_)), + maybe_format(HANDLER(prepend_format_)), + HANDLER(prepend_width_).value.to_long()), + *this, "#cleared")); } else if (is_eq(p, "convert")) { - return WRAP_FUNCTOR(convert_command); + return WRAP_FUNCTOR(convert_command); } else if (is_eq(p, "commodities")) { - return WRAP_FUNCTOR(reporter<>(new report_commodities(*this), *this, - "#commodities")); + return WRAP_FUNCTOR(reporter<>(new report_commodities(*this), *this, + "#commodities")); } break; case 'e': if (is_eq(p, "equity")) { - HANDLER(print_virtual).on_only(string("#equity")); - return WRAP_FUNCTOR(reporter<>(new print_xacts(*this), *this, "#equity")); + HANDLER(generated).on_only(string("#equity")); + return WRAP_FUNCTOR(reporter<>(new print_xacts(*this), *this, "#equity")); } else if (is_eq(p, "entry")) { - return WRAP_FUNCTOR(xact_command); + return WRAP_FUNCTOR(xact_command); } else if (is_eq(p, "emacs")) { - return WRAP_FUNCTOR - (reporter<>(new format_emacs_posts(output_stream), *this, "#emacs")); + return WRAP_FUNCTOR + (reporter<>(new format_emacs_posts(output_stream), *this, "#emacs")); } else if (is_eq(p, "echo")) { - return MAKE_FUNCTOR(report_t::echo_command); + return MAKE_FUNCTOR(report_t::echo_command); } break; case 'p': if (*(p + 1) == '\0' || is_eq(p, "print")) { - return WRAP_FUNCTOR - (reporter<>(new print_xacts(*this, HANDLED(raw)), *this, "#print")); + return WRAP_FUNCTOR + (reporter<>(new print_xacts(*this, HANDLED(raw)), *this, "#print")); } else if (is_eq(p, "prices")) { - return expr_t::op_t::wrap_functor - (reporter<post_t, post_handler_ptr, &report_t::commodities_report> - (new format_posts(*this, report_format(HANDLER(prices_format_)), - maybe_format(HANDLER(prepend_format_)), - HANDLER(prepend_width_).value.to_long()), - *this, "#prices")); + return expr_t::op_t::wrap_functor + (reporter<post_t, post_handler_ptr, &report_t::commodities_report> + (new format_posts(*this, report_format(HANDLER(prices_format_)), + maybe_format(HANDLER(prepend_format_)), + HANDLER(prepend_width_).value.to_long()), + *this, "#prices")); } else if (is_eq(p, "pricedb")) { - return expr_t::op_t::wrap_functor - (reporter<post_t, post_handler_ptr, &report_t::commodities_report> - (new format_posts(*this, report_format(HANDLER(pricedb_format_)), - maybe_format(HANDLER(prepend_format_)), - HANDLER(prepend_width_).value.to_long()), - *this, "#pricedb")); + return expr_t::op_t::wrap_functor + (reporter<post_t, post_handler_ptr, &report_t::commodities_report> + (new format_posts(*this, report_format(HANDLER(pricedb_format_)), + maybe_format(HANDLER(prepend_format_)), + HANDLER(prepend_width_).value.to_long()), + *this, "#pricedb")); } else if (is_eq(p, "pricemap")) { - return MAKE_FUNCTOR(report_t::pricemap_command); + return MAKE_FUNCTOR(report_t::pricemap_command); } else if (is_eq(p, "payees")) { - return WRAP_FUNCTOR(reporter<>(new report_payees(*this), *this, - "#payees")); + return WRAP_FUNCTOR(reporter<>(new report_payees(*this), *this, + "#payees")); } break; case 'r': if (*(p + 1) == '\0' || is_eq(p, "reg") || is_eq(p, "register")) { - return WRAP_FUNCTOR - (reporter<> - (new format_posts(*this, report_format(HANDLER(register_format_)), - maybe_format(HANDLER(prepend_format_)), - HANDLER(prepend_width_).value.to_long()), - *this, "#register")); + return WRAP_FUNCTOR + (reporter<> + (new format_posts(*this, report_format(HANDLER(register_format_)), + maybe_format(HANDLER(prepend_format_)), + HANDLER(prepend_width_).value.to_long()), + *this, "#register")); } else if (is_eq(p, "reload")) { - return MAKE_FUNCTOR(report_t::reload_command); + return MAKE_FUNCTOR(report_t::reload_command); } break; case 's': if (is_eq(p, "stats") || is_eq(p, "stat")) - return WRAP_FUNCTOR(report_statistics); + return WRAP_FUNCTOR(report_statistics); break; case 'x': if (is_eq(p, "xact")) - return WRAP_FUNCTOR(xact_command); + return WRAP_FUNCTOR(xact_command); else if (is_eq(p, "xml")) - return WRAP_FUNCTOR(reporter<>(new format_xml(*this), *this, "#xml")); + return WRAP_FUNCTOR(reporter<>(new format_xml(*this), *this, "#xml")); break; } break; @@ -1475,39 +1478,38 @@ expr_t::ptr_op_t report_t::lookup(const symbol_t::kind_t kind, switch (*p) { case 'a': if (is_eq(p, "args")) - return WRAP_FUNCTOR(query_command); + return WRAP_FUNCTOR(query_command); break; case 'e': if (is_eq(p, "eval")) - return WRAP_FUNCTOR(eval_command); + return WRAP_FUNCTOR(eval_command); else if (is_eq(p, "expr")) - return WRAP_FUNCTOR(parse_command); + return WRAP_FUNCTOR(parse_command); break; case 'f': if (is_eq(p, "format")) - return WRAP_FUNCTOR(format_command); + return WRAP_FUNCTOR(format_command); break; case 'g': if (is_eq(p, "generate")) { - HANDLER(print_virtual).on_only(string("#generate")); - return expr_t::op_t::wrap_functor - (reporter<post_t, post_handler_ptr, &report_t::generate_report> - (new print_xacts(*this), *this, "#generate")); + return expr_t::op_t::wrap_functor + (reporter<post_t, post_handler_ptr, &report_t::generate_report> + (new print_xacts(*this), *this, "#generate")); } break; case 'p': if (is_eq(p, "parse")) - return WRAP_FUNCTOR(parse_command); + return WRAP_FUNCTOR(parse_command); else if (is_eq(p, "period")) - return WRAP_FUNCTOR(period_command); + return WRAP_FUNCTOR(period_command); break; case 'q': if (is_eq(p, "query")) - return WRAP_FUNCTOR(query_command); + return WRAP_FUNCTOR(query_command); break; case 't': if (is_eq(p, "template")) - return WRAP_FUNCTOR(template_command); + return WRAP_FUNCTOR(template_command); break; } break; diff --git a/src/report.h b/src/report.h index f8fdf507..082c204b 100644 --- a/src/report.h +++ b/src/report.h @@ -107,11 +107,11 @@ class report_t : public scope_t report_t(); public: - session_t& session; + session_t& session; output_stream_t output_stream; #define BUDGET_NO_BUDGET 0x00 -#define BUDGET_BUDGETED 0x01 +#define BUDGET_BUDGETED 0x01 #define BUDGET_UNBUDGETED 0x02 #define BUDGET_WRAP_VALUES 0x04 @@ -160,6 +160,7 @@ public: value_t fn_ansify_if(call_scope_t& scope); value_t fn_percent(call_scope_t& scope); value_t fn_price(call_scope_t& scope); + value_t fn_commodity(call_scope_t& scope); value_t fn_lot_date(call_scope_t& scope); value_t fn_lot_price(call_scope_t& scope); value_t fn_lot_tag(call_scope_t& scope); @@ -203,9 +204,9 @@ public: keep_details_t what_to_keep() { bool lots = HANDLED(lots) || HANDLED(lots_actual); return keep_details_t(lots || HANDLED(lot_prices), - lots || HANDLED(lot_dates), - lots || HANDLED(lot_tags), - HANDLED(lots_actual)); + lots || HANDLED(lot_dates), + lots || HANDLED(lot_tags), + HANDLED(lots_actual)); } void report_options(std::ostream& out) @@ -257,6 +258,7 @@ public: HANDLER(forecast_years_).report(out); HANDLER(format_).report(out); HANDLER(gain).report(out); + HANDLER(generated).report(out); HANDLER(group_by_).report(out); HANDLER(group_title_format_).report(out); HANDLER(head_).report(out); @@ -289,7 +291,6 @@ public: HANDLER(price).report(out); HANDLER(prices_format_).report(out); HANDLER(pricedb_format_).report(out); - HANDLER(print_virtual).report(out); HANDLER(quantity).report(out); HANDLER(quarterly).report(out); HANDLER(raw).report(out); @@ -331,17 +332,17 @@ public: option_t<report_t> * lookup_option(const char * p); virtual void define(const symbol_t::kind_t kind, const string& name, - expr_t::ptr_op_t def); + expr_t::ptr_op_t def); virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name); + const string& name); /** * Option handlers */ OPTION__(report_t, abbrev_len_, - CTOR(report_t, abbrev_len_) { on_with(none, 2L); }); + CTOR(report_t, abbrev_len_) { on_with(none, 2L); }); OPTION(report_t, account_); OPTION_(report_t, actual, DO() { // -L @@ -373,16 +374,16 @@ public: OPTION_(report_t, average, DO() { // -A parent->HANDLER(display_total_) - .set_expr(string("--average"), "count>0?(total_expr/count):0"); + .set_expr(string("--average"), "count>0?(total_expr/count):0"); }); OPTION__(report_t, balance_format_, CTOR(report_t, balance_format_) { on(none, - "%(justify(scrub(display_total), 20, 20 + prepend_width, true, color))" - " %(!options.flat ? depth_spacer : \"\")" - "%-(ansify_if(partial_account(options.flat), blue if color))\n%/" - "%$1\n%/" - "--------------------\n"); + "%(justify(scrub(display_total), 20, 20 + prepend_width, true, color))" + " %(!options.flat ? depth_spacer : \"\")" + "%-(ansify_if(partial_account(options.flat), blue if color))\n%/" + "%$1\n%/" + "--------------------\n"); }); OPTION(report_t, base); @@ -396,9 +397,9 @@ public: date_interval_t interval(args[1].to_string()); optional<date_t> begin = interval.begin(parent->session.current_year); if (! begin) - throw_(std::invalid_argument, - _("Could not determine beginning of period '%1'") - << args[1].to_string()); + throw_(std::invalid_argument, + _("Could not determine beginning of period '%1'") + << args[1].to_string()); string predicate = "date>=[" + to_iso_extended_string(*begin) + "]"; parent->HANDLER(limit_).on(string("--begin"), predicate); @@ -410,24 +411,24 @@ public: OPTION__(report_t, budget_format_, CTOR(report_t, budget_format_) { on(none, - "%(justify(scrub(get_at(total_expr, 0)), 12, -1, true, color))" - " %(justify(scrub(- get_at(total_expr, 1)), 12, " - " 12 + 1 + 12, true, color))" - " %(justify(scrub(get_at(total_expr, 1) + " - " get_at(total_expr, 0)), 12, " - " 12 + 1 + 12 + 1 + 12, true, color))" - " %(ansify_if(" - " justify((get_at(total_expr, 1) ? " - " scrub((100% * get_at(total_expr, 0)) / " - " - get_at(total_expr, 1)) : 0), " - " 5, -1, true, false)," - " magenta if (color and get_at(total_expr, 1) and " - " (abs(quantity(get_at(total_expr, 0)) / " - " quantity(get_at(total_expr, 1))) >= 1))))" - " %(!options.flat ? depth_spacer : \"\")" - "%-(ansify_if(partial_account(options.flat), blue if color))\n" - "%/%$1 %$2 %$3 %$4\n%/" - "------------ ------------ ------------ -----\n"); + "%(justify(scrub(get_at(total_expr, 0)), 12, -1, true, color))" + " %(justify(-scrub(get_at(total_expr, 1)), 12, " + " 12 + 1 + 12, true, color))" + " %(justify(scrub(get_at(total_expr, 1) + " + " get_at(total_expr, 0)), 12, " + " 12 + 1 + 12 + 1 + 12, true, color))" + " %(ansify_if(" + " justify((get_at(total_expr, 1) ? " + " (100% * scrub(get_at(total_expr, 0))) / " + " -scrub(get_at(total_expr, 1)) : 0), " + " 5, -1, true, false)," + " magenta if (color and get_at(total_expr, 1) and " + " (abs(quantity(scrub(get_at(total_expr, 0))) / " + " quantity(scrub(get_at(total_expr, 1)))) >= 1))))" + " %(!options.flat ? depth_spacer : \"\")" + "%-(ansify_if(partial_account(options.flat), blue if color))\n" + "%/%$1 %$2 %$3 %$4\n%/" + "------------ ------------ ------------ -----\n"); }); OPTION(report_t, by_payee); // -P @@ -438,14 +439,14 @@ public: OPTION__(report_t, cleared_format_, CTOR(report_t, cleared_format_) { on(none, - "%(justify(scrub(get_at(total_expr, 0)), 16, 16 + prepend_width, " - " true, color)) %(justify(scrub(get_at(total_expr, 1)), 18, " - " 36 + prepend_width, true, color))" - " %(latest_cleared ? format_date(latest_cleared) : \" \")" - " %(!options.flat ? depth_spacer : \"\")" - "%-(ansify_if(partial_account(options.flat), blue if color))\n%/" - "%$1 %$2 %$3\n%/" - "---------------- ---------------- ---------\n"); + "%(justify(scrub(get_at(total_expr, 0)), 16, 16 + prepend_width, " + " true, color)) %(justify(scrub(get_at(total_expr, 1)), 18, " + " 36 + prepend_width, true, color))" + " %(latest_cleared ? format_date(latest_cleared) : \" \")" + " %(!options.flat ? depth_spacer : \"\")" + "%-(ansify_if(partial_account(options.flat), blue if color))\n%/" + "%$1 %$2 %$3\n%/" + "---------------- ---------------- ---------\n"); }); OPTION(report_t, color); @@ -465,14 +466,14 @@ public: OPTION__(report_t, csv_format_, CTOR(report_t, csv_format_) { on(none, - "%(quoted(date))," - "%(quoted(code))," - "%(quoted(payee))," - "%(quoted(display_account))," - "%(quoted(commodity))," - "%(quoted(quantity(scrub(display_amount))))," - "%(quoted(cleared ? \"*\" : (pending ? \"!\" : \"\")))," - "%(quoted(join(note | xact.note)))\n"); + "%(quoted(date))," + "%(quoted(code))," + "%(quoted(payee))," + "%(quoted(display_account))," + "%(quoted(commodity))," + "%(quoted(quantity(scrub(display_amount))))," + "%(quoted(cleared ? \"*\" : (pending ? \"!\" : \"\")))," + "%(quoted(join(note | xact.note)))\n"); }); OPTION_(report_t, current, DO() { // -c @@ -490,12 +491,12 @@ public: OPTION_(report_t, depth_, DO_(scope) { interactive_t args(scope, "sl"); parent->HANDLER(display_).on(string("--depth"), - string("depth<=") + args.get<string>(1)); + string("depth<=") + args.get<string>(1)); }); OPTION_(report_t, deviation, DO() { parent->HANDLER(display_total_) - .set_expr(string("--deviation"), "amount_expr-total_expr/count"); + .set_expr(string("--deviation"), "amount_expr-total_expr/count"); }); OPTION__ @@ -506,8 +507,8 @@ public: option_t<report_t>::on_with(whence, text); else option_t<report_t>::on_with(whence, - string_value(string("(") + str() + ")&(" + - text.as_string() + ")")); + string_value(string("(") + str() + ")&(" + + text.as_string() + ")")); }); OPTION__ @@ -548,9 +549,9 @@ public: // 2008/01/01 instead of 2009/01/01 (which is what end() would return). optional<date_t> end = interval.begin(parent->session.current_year); if (! end) - throw_(std::invalid_argument, - _("Could not determine end of period '%1'") - << args[1].to_string()); + throw_(std::invalid_argument, + _("Could not determine end of period '%1'") + << args[1].to_string()); string predicate = "date<[" + to_iso_extended_string(*end) + "]"; parent->HANDLER(limit_).on(string("--end"), predicate); @@ -582,23 +583,25 @@ public: // Since we are displaying the amounts of revalued postings, they // will end up being composite totals, and hence a pair of pairs. parent->HANDLER(display_amount_) - .set_expr(string("--gain"), - "use_direct_amount ? amount :" - " (is_seq(get_at(amount_expr, 0)) ?" - " get_at(get_at(amount_expr, 0), 0) :" - " market(get_at(amount_expr, 0), value_date, exchange)" - " - get_at(amount_expr, 1))"); + .set_expr(string("--gain"), + "use_direct_amount ? amount :" + " (is_seq(get_at(amount_expr, 0)) ?" + " get_at(get_at(amount_expr, 0), 0) :" + " market(get_at(amount_expr, 0), value_date, exchange)" + " - get_at(amount_expr, 1))"); parent->HANDLER(revalued_total_) - .set_expr(string("--gain"), - "(market(get_at(total_expr, 0), value_date, exchange), " - "get_at(total_expr, 1))"); + .set_expr(string("--gain"), + "(market(get_at(total_expr, 0), value_date, exchange), " + "get_at(total_expr, 1))"); parent->HANDLER(display_total_) - .set_expr(string("--gain"), - "use_direct_amount ? total_expr :" - " market(get_at(total_expr, 0), value_date, exchange)" - " - get_at(total_expr, 1)"); + .set_expr(string("--gain"), + "use_direct_amount ? total_expr :" + " market(get_at(total_expr, 0), value_date, exchange)" + " - get_at(total_expr, 1)"); }); + OPTION(report_t, generated); + OPTION__ (report_t, group_by_, expr_t expr; @@ -629,8 +632,8 @@ public: option_t<report_t>::on_with(whence, text); else option_t<report_t>::on_with(whence, - string_value(string("(") + str() + ")&(" + - text.as_string() + ")")); + string_value(string("(") + str() + ")&(" + + text.as_string() + ")")); }); OPTION(report_t, lot_dates); @@ -642,11 +645,11 @@ public: OPTION_(report_t, market, DO() { // -V parent->HANDLER(revalued).on_only(string("--market")); parent->HANDLER(display_amount_) - .set_expr(string("--market"), - "market(amount_expr, value_date, exchange)"); + .set_expr(string("--market"), + "market(amount_expr, value_date, exchange)"); parent->HANDLER(display_total_) - .set_expr(string("--market"), - "market(total_expr, value_date, exchange)"); + .set_expr(string("--market"), + "market(total_expr, value_date, exchange)"); }); OPTION(report_t, meta_); @@ -667,9 +670,9 @@ public: date_interval_t interval(args[1].to_string()); optional<date_t> begin = interval.begin(parent->session.current_year); if (! begin) - throw_(std::invalid_argument, - _("Could not determine beginning of period '%1'") - << args[1].to_string()); + throw_(std::invalid_argument, + _("Could not determine beginning of period '%1'") + << args[1].to_string()); ledger::epoch = parent->terminus = datetime_t(*begin); parent->session.current_year = ledger::epoch->date().year(); }); @@ -682,8 +685,8 @@ public: option_t<report_t>::on_with(whence, text); else option_t<report_t>::on_with(whence, - string_value(string("(") + str() + ")&(" + - text.as_string() + ")")); + string_value(string("(") + str() + ")&(" + + text.as_string() + ")")); }); OPTION(report_t, output_); // -o @@ -695,20 +698,20 @@ public: if (! std::getenv("PAGER") && isatty(STDOUT_FILENO)) { bool have_less = false; if (exists(path("/opt/local/bin/less")) || - exists(path("/usr/local/bin/less")) || - exists(path("/usr/bin/less"))) - have_less = true; + exists(path("/usr/local/bin/less")) || + exists(path("/usr/bin/less"))) + have_less = true; if (have_less) { - on(none, "less"); - setenv("LESS", "-FRSX", 0); // don't overwrite + on(none, "less"); + setenv("LESS", "-FRSX", 0); // don't overwrite } } } virtual void on_with(const optional<string>& whence, const value_t& text) { string cmd(text.to_string()); if (cmd == "" || cmd == "false" || cmd == "off" || - cmd == "none" || cmd == "no" || cmd == "disable") + cmd == "none" || cmd == "no" || cmd == "disable") option_t<report_t>::off(); else option_t<report_t>::on_with(whence, text); @@ -721,7 +724,7 @@ public: virtual void on_with(const optional<string>& whence, const value_t& text) { string cmd(text.to_string()); if (cmd == "" || cmd == "false" || cmd == "off" || - cmd == "none" || cmd == "no" || cmd == "disable") + cmd == "none" || cmd == "no" || cmd == "disable") option_t<report_t>::off(); else option_t<report_t>::on_with(whence, text); @@ -736,8 +739,9 @@ public: OPTION_(report_t, percent, DO() { // -% parent->HANDLER(total_) - .set_expr(string("--percent"), - "((is_account&parent&parent.total)?percent(total, parent.total):0"); + .set_expr(string("--percent"), + "((is_account&parent&parent.total)?" + " percent(scrub(total), scrub(parent.total)):0"); }); OPTION__ @@ -748,19 +752,19 @@ public: option_t<report_t>::on_with(whence, text); else option_t<report_t>::on_with(whence, - string_value(text.as_string() + " " + str())); + string_value(text.as_string() + " " + str())); }); OPTION(report_t, pivot_); OPTION__(report_t, plot_amount_format_, CTOR(report_t, plot_amount_format_) { on(none, - "%(format_date(date, \"%Y-%m-%d\")) %(quantity(scrub(display_amount)))\n"); + "%(format_date(date, \"%Y-%m-%d\")) %(quantity(scrub(display_amount)))\n"); }); OPTION__(report_t, plot_total_format_, CTOR(report_t, plot_total_format_) { on(none, - "%(format_date(date, \"%Y-%m-%d\")) %(quantity(scrub(display_total)))\n"); + "%(format_date(date, \"%Y-%m-%d\")) %(quantity(scrub(display_total)))\n"); }); OPTION(report_t, prepend_format_); @@ -770,24 +774,22 @@ public: OPTION_(report_t, price, DO() { // -I parent->HANDLER(display_amount_) - .set_expr(string("--price"), "price(amount_expr)"); + .set_expr(string("--price"), "price(amount_expr)"); parent->HANDLER(display_total_) - .set_expr(string("--price"), "price(total_expr)"); + .set_expr(string("--price"), "price(total_expr)"); }); OPTION__(report_t, prices_format_, CTOR(report_t, prices_format_) { on(none, - "%(date) %-8(display_account) %(justify(scrub(display_amount), 12, " - " 2 + 9 + 8 + 12, true, color))\n"); + "%(date) %-8(display_account) %(justify(scrub(display_amount), 12, " + " 2 + 9 + 8 + 12, true, color))\n"); }); OPTION__(report_t, pricedb_format_, CTOR(report_t, pricedb_format_) { on(none, - "P %(datetime) %(display_account) %(scrub(display_amount))\n"); + "P %(datetime) %(display_account) %(scrub(display_amount))\n"); }); - OPTION(report_t, print_virtual); - OPTION_(report_t, quantity, DO() { // -O parent->HANDLER(revalued).off(); parent->HANDLER(amount_).set_expr(string("--quantity"), "amount"); @@ -806,20 +808,20 @@ public: OPTION__(report_t, register_format_, CTOR(report_t, register_format_) { on(none, - "%(ansify_if(justify(format_date(date), date_width), green " - " if color & date > today))" - " %(ansify_if(justify(truncated(payee, payee_width), payee_width), " - " bold if color & !cleared & actual))" - " %(ansify_if(justify(truncated(display_account, account_width, " - " abbrev_len), account_width), blue if color))" - " %(justify(scrub(display_amount), amount_width, " - " 3 + meta_width + date_width + payee_width + account_width" - " + amount_width + prepend_width, true, color))" - " %(justify(scrub(display_total), total_width, " - " 4 + meta_width + date_width + payee_width + account_width" - " + amount_width + total_width + prepend_width, true, color))\n%/" - "%(justify(\" \", 2 + date_width + payee_width))" - "%$3 %$4 %$5\n"); + "%(ansify_if(justify(format_date(date), date_width), green " + " if color & date > today))" + " %(ansify_if(justify(truncated(payee, payee_width), payee_width), " + " bold if color & !cleared & actual))" + " %(ansify_if(justify(truncated(display_account, account_width, " + " abbrev_len), account_width), blue if color))" + " %(justify(scrub(display_amount), amount_width, " + " 3 + meta_width + date_width + payee_width + account_width" + " + amount_width + prepend_width, true, color))" + " %(justify(scrub(display_total), total_width, " + " 4 + meta_width + date_width + payee_width + account_width" + " + amount_width + total_width + prepend_width, true, color))\n%/" + "%(justify(\" \", 2 + date_width + payee_width))" + "%$3 %$4 %$5\n"); }); OPTION(report_t, related); // -r @@ -884,14 +886,14 @@ public: OPTION_(report_t, truncate_, DO_(args) { string style(args[1].to_string()); if (style == "leading") - format_t::default_style = format_t::TRUNCATE_LEADING; + format_t::default_style = format_t::TRUNCATE_LEADING; else if (style == "middle") - format_t::default_style = format_t::TRUNCATE_MIDDLE; + format_t::default_style = format_t::TRUNCATE_MIDDLE; else if (style == "trailing") - format_t::default_style = format_t::TRUNCATE_TRAILING; + format_t::default_style = format_t::TRUNCATE_TRAILING; else - throw_(std::invalid_argument, - _("Unrecognized truncation style: '%1'") << style); + throw_(std::invalid_argument, + _("Unrecognized truncation style: '%1'") << style); format_t::default_style_changed = true; }); @@ -910,9 +912,9 @@ public: OPTION_(report_t, unround, DO() { parent->HANDLER(display_amount_) - .set_expr(string("--unround"), "unrounded(amount_expr)"); + .set_expr(string("--unround"), "unrounded(amount_expr)"); parent->HANDLER(display_total_) - .set_expr(string("--unround"), "unrounded(total_expr)"); + .set_expr(string("--unround"), "unrounded(total_expr)"); }); OPTION(report_t, unsorted); @@ -930,36 +932,36 @@ public: }); OPTION__(report_t, meta_width_, - bool specified; - CTOR(report_t, meta_width_) { specified = false; } - DO_(args) { value = args[1].to_long(); specified = true; }); + bool specified; + CTOR(report_t, meta_width_) { specified = false; } + DO_(args) { value = args[1].to_long(); specified = true; }); OPTION__(report_t, date_width_, - bool specified; - CTOR(report_t, date_width_) { specified = false; } - DO_(args) { value = args[1].to_long(); specified = true; }); + bool specified; + CTOR(report_t, date_width_) { specified = false; } + DO_(args) { value = args[1].to_long(); specified = true; }); OPTION__(report_t, payee_width_, - bool specified; - CTOR(report_t, payee_width_) { specified = false; } - DO_(args) { value = args[1].to_long(); specified = true; }); + bool specified; + CTOR(report_t, payee_width_) { specified = false; } + DO_(args) { value = args[1].to_long(); specified = true; }); OPTION__(report_t, account_width_, - bool specified; - CTOR(report_t, account_width_) { specified = false; } - DO_(args) { value = args[1].to_long(); specified = true; }); + bool specified; + CTOR(report_t, account_width_) { specified = false; } + DO_(args) { value = args[1].to_long(); specified = true; }); OPTION__(report_t, amount_width_, - bool specified; - CTOR(report_t, amount_width_) { specified = false; } - DO_(args) { value = args[1].to_long(); specified = true; }); + bool specified; + CTOR(report_t, amount_width_) { specified = false; } + DO_(args) { value = args[1].to_long(); specified = true; }); OPTION__(report_t, total_width_, - bool specified; - CTOR(report_t, total_width_) { specified = false; } - DO_(args) { value = args[1].to_long(); specified = true; }); + bool specified; + CTOR(report_t, total_width_) { specified = false; } + DO_(args) { value = args[1].to_long(); specified = true; }); }; template <class Type = post_t, - class handler_ptr = post_handler_ptr, - void (report_t::*report_method)(handler_ptr) = - &report_t::posts_report> + class handler_ptr = post_handler_ptr, + void (report_t::*report_method)(handler_ptr) = + &report_t::posts_report> class reporter { shared_ptr<item_handler<Type> > handler; @@ -969,7 +971,7 @@ class reporter public: reporter(item_handler<Type> * _handler, - report_t& _report, const string& _whence) + report_t& _report, const string& _whence) : handler(_handler), report(_report), whence(_whence) {} value_t operator()(call_scope_t& args) diff --git a/src/scope.cc b/src/scope.cc index 72cf4ad3..faad352a 100644 --- a/src/scope.cc +++ b/src/scope.cc @@ -38,7 +38,7 @@ namespace ledger { scope_t * scope_t::default_scope = NULL; void symbol_scope_t::define(const symbol_t::kind_t kind, - const string& name, expr_t::ptr_op_t def) + const string& name, expr_t::ptr_op_t def) { DEBUG("scope.symbols", "Defining '" << name << "' = " << def); @@ -53,15 +53,15 @@ void symbol_scope_t::define(const symbol_t::kind_t kind, symbols->erase(i); result = symbols->insert(symbol_map::value_type(symbol_t(kind, name, def), - def)); + def)); if (! result.second) throw_(compile_error, - _("Redefinition of '%1' in the same scope") << name); + _("Redefinition of '%1' in the same scope") << name); } } expr_t::ptr_op_t symbol_scope_t::lookup(const symbol_t::kind_t kind, - const string& name) + const string& name) { if (symbols) { symbol_map::const_iterator i = symbols->find(symbol_t(kind, name)); diff --git a/src/scope.h b/src/scope.h index 1e6f24a1..e3dd3e3f 100644 --- a/src/scope.h +++ b/src/scope.h @@ -58,8 +58,8 @@ struct symbol_t FORMAT }; - kind_t kind; - string name; + kind_t kind; + string name; expr_t::ptr_op_t definition; symbol_t() : kind(UNKNOWN), name(""), definition(NULL) { @@ -110,9 +110,9 @@ public: } virtual void define(const symbol_t::kind_t, const string&, - expr_t::ptr_op_t) {} + expr_t::ptr_op_t) {} virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name) = 0; + const string& name) = 0; #if defined(HAVE_BOOST_SERIALIZATION) private: @@ -142,13 +142,13 @@ public: } virtual void define(const symbol_t::kind_t kind, - const string& name, expr_t::ptr_op_t def) { + const string& name, expr_t::ptr_op_t def) { if (parent) parent->define(kind, name, def); } virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name) { + const string& name) { if (parent) return parent->lookup(kind, name); return NULL; @@ -186,10 +186,10 @@ public: } virtual void define(const symbol_t::kind_t kind, const string& name, - expr_t::ptr_op_t def); + expr_t::ptr_op_t def); virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name); + const string& name); #if defined(HAVE_BOOST_SERIALIZATION) private: @@ -292,7 +292,7 @@ public: scope_t& grandchild; explicit bind_scope_t(scope_t& _parent, - scope_t& _grandchild) + scope_t& _grandchild) : child_scope_t(_parent), grandchild(_grandchild) { TRACE_CTOR(bind_scope_t, "scope_t&, scope_t&"); } @@ -301,13 +301,13 @@ public: } virtual void define(const symbol_t::kind_t kind, const string& name, - expr_t::ptr_op_t def) { + expr_t::ptr_op_t def) { parent->define(kind, name, def); grandchild.define(kind, name, def); } virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name) { + const string& name) { if (expr_t::ptr_op_t def = grandchild.lookup(kind, name)) return def; return child_scope_t::lookup(kind, name); @@ -366,7 +366,7 @@ public: value_scope_t(const value_t& _value) : value(_value) {} virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name) + const string& name) { if (kind != symbol_t::FUNCTION) return NULL; diff --git a/src/session.cc b/src/session.cc index f8befde4..8adfef38 100644 --- a/src/session.cc +++ b/src/session.cc @@ -105,37 +105,37 @@ std::size_t session_t::read_data(const string& master_account) cache = archive_t(HANDLED(cache_).str()); if (! (cache && - cache->should_load(HANDLER(file_).data_files) && - cache->load(*journal.get()))) { + cache->should_load(HANDLER(file_).data_files) && + cache->load(*journal.get()))) { #endif // HAVE_BOOST_SERIALIZATION if (price_db_path) { if (exists(*price_db_path)) { - if (journal->read(*price_db_path) > 0) - throw_(parse_error, _("Transactions not allowed in price history file")); + if (journal->read(*price_db_path) > 0) + throw_(parse_error, _("Transactions not allowed in price history file")); } } foreach (const path& pathname, HANDLER(file_).data_files) { if (pathname == "-") { - // To avoid problems with stdin and pipes, etc., we read the entire - // file in beforehand into a memory buffer, and then parcel it out - // from there. - std::ostringstream buffer; - - while (std::cin.good() && ! std::cin.eof()) { - char line[8192]; - std::cin.read(line, 8192); - std::streamsize count = std::cin.gcount(); - buffer.write(line, count); - } - buffer.flush(); - - std::istringstream buf_in(buffer.str()); - - xact_count += journal->read(buf_in, "/dev/stdin", acct); - journal->sources.push_back(journal_t::fileinfo_t()); + // To avoid problems with stdin and pipes, etc., we read the entire + // file in beforehand into a memory buffer, and then parcel it out + // from there. + std::ostringstream buffer; + + while (std::cin.good() && ! std::cin.eof()) { + char line[8192]; + std::cin.read(line, 8192); + std::streamsize count = std::cin.gcount(); + buffer.write(line, count); + } + buffer.flush(); + + std::istringstream buf_in(buffer.str()); + + xact_count += journal->read(buf_in, "/dev/stdin", acct); + journal->sources.push_back(journal_t::fileinfo_t()); } else { - xact_count += journal->read(pathname, acct); + xact_count += journal->read(pathname, acct); } } @@ -166,7 +166,7 @@ void session_t::read_journal_files() std::size_t count = read_data(master_account); if (count == 0) throw_(parse_error, - _("Failed to locate any transactions; did you specify a valid file with -f?")); + _("Failed to locate any transactions; did you specify a valid file with -f?")); INFO_FINISH(journal); @@ -222,7 +222,7 @@ option_t<session_t> * session_t::lookup_option(const char * p) } expr_t::ptr_op_t session_t::lookup(const symbol_t::kind_t kind, - const string& name) + const string& name) { switch (kind) { case symbol_t::FUNCTION: diff --git a/src/session.h b/src/session.h index 3916b964..4968f1b8 100644 --- a/src/session.h +++ b/src/session.h @@ -57,8 +57,8 @@ class session_t : public symbol_scope_t friend void set_session_context(session_t * session); public: - bool flush_on_next_data_file; - date_t::year_type current_year; + bool flush_on_next_data_file; + date_t::year_type current_year; std::auto_ptr<journal_t> journal; explicit session_t(); @@ -91,7 +91,7 @@ public: option_t<session_t> * lookup_option(const char * p); virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name); + const string& name); /** * Option handlers diff --git a/src/stats.cc b/src/stats.cc index 86a8338d..172971aa 100644 --- a/src/stats.cc +++ b/src/stats.cc @@ -58,11 +58,11 @@ value_t report_statistics(call_scope_t& args) { straccstream accum; out << ACCUM(accum << _("Time period: %1 to %2 (%3 days)") - << format_date(statistics.earliest_post) - << format_date(statistics.latest_post) - << (statistics.latest_post - - statistics.earliest_post).days()) - << std::endl << std::endl; + << format_date(statistics.earliest_post) + << format_date(statistics.latest_post) + << (statistics.latest_post - + statistics.earliest_post).days()) + << std::endl << std::endl; } out << _(" Files these postings came from:") << std::endl; @@ -89,12 +89,12 @@ value_t report_statistics(call_scope_t& args) out << " ("; out.precision(2); out << (double((statistics.latest_post - statistics.earliest_post).days()) / - double(statistics.posts_count)) << _(" per day)") << std::endl; + double(statistics.posts_count)) << _(" per day)") << std::endl; out << _(" Uncleared postings: "); out.width(6); out << (statistics.posts_count - - statistics.posts_cleared_count) << std::endl; + statistics.posts_cleared_count) << std::endl; out << std::endl; diff --git a/src/stream.cc b/src/stream.cc index 272d4f1c..79faa05a 100644 --- a/src/stream.cc +++ b/src/stream.cc @@ -73,11 +73,11 @@ namespace { if (status < 0) { throw std::logic_error(_("Failed to fork child process")); } - else if (status == 0) { // child + else if (status == 0) { // child // Duplicate pipe's reading end into stdin status = dup2(pfd[0], STDIN_FILENO); if (status == -1) - perror("dup2"); + perror("dup2"); // Close unuseful file descriptors: the pipe's writing and reading // ends (the latter is not needed anymore, after the duplication). @@ -98,7 +98,7 @@ namespace { perror((std::string("execlp: ") + pager_path.string()).c_str()); exit(1); } - else { // parent + else { // parent close(pfd[0]); typedef iostreams::stream<iostreams::file_descriptor_sink> fdstream; *os = new fdstream(pfd[1]); @@ -108,7 +108,7 @@ namespace { } void output_stream_t::initialize(const optional<path>& output_file, - const optional<path>& pager_path) + const optional<path>& pager_path) { if (output_file && *output_file != "-") os = new ofstream(*output_file); diff --git a/src/stream.h b/src/stream.h index 356df08c..42c85534 100644 --- a/src/stream.h +++ b/src/stream.h @@ -114,7 +114,7 @@ public: * empty. */ void initialize(const optional<path>& output_file = none, - const optional<path>& pager_path = none); + const optional<path>& pager_path = none); /** * Convertor to a standard ostream. This is used so that we can diff --git a/src/system.hh.in b/src/system.hh.in index 5de7150e..34efa424 100644 --- a/src/system.hh.in +++ b/src/system.hh.in @@ -159,6 +159,7 @@ typedef std::ostream::pos_type ostream_pos_type; #include <boost/operators.hpp> #include <boost/optional.hpp> #include <boost/ptr_container/ptr_list.hpp> +#include <boost/ptr_container/serialize_ptr_deque.hpp> #include <boost/random/mersenne_twister.hpp> #include <boost/random/uniform_int.hpp> #include <boost/random/uniform_real.hpp> diff --git a/src/temps.cc b/src/temps.cc index 7a630176..365c33c5 100644 --- a/src/temps.cc +++ b/src/temps.cc @@ -63,7 +63,7 @@ xact_t& temporaries_t::create_xact() } post_t& temporaries_t::copy_post(post_t& origin, xact_t& xact, - account_t * account) + account_t * account) { if (! post_temps) post_temps = std::list<post_t>(); @@ -99,7 +99,7 @@ post_t& temporaries_t::create_post(xact_t& xact, account_t * account) } account_t& temporaries_t::create_account(const string& name, - account_t * parent) + account_t * parent) { if (! acct_temps) acct_temps = std::list<account_t>(); @@ -119,10 +119,10 @@ void temporaries_t::clear() if (post_temps) { foreach (post_t& post, *post_temps) { if (! post.xact->has_flags(ITEM_TEMP)) - post.xact->remove_post(&post); + post.xact->remove_post(&post); if (post.account && ! post.account->has_flags(ACCOUNT_TEMP)) - post.account->remove_post(&post); + post.account->remove_post(&post); } post_temps->clear(); } @@ -133,7 +133,7 @@ void temporaries_t::clear() if (acct_temps) { foreach (account_t& acct, *acct_temps) { if (acct.parent && ! acct.parent->has_flags(ACCOUNT_TEMP)) - acct.parent->remove_account(&acct); + acct.parent->remove_account(&acct); } acct_temps->clear(); } diff --git a/src/temps.h b/src/temps.h index 210bbf63..1e7eb69f 100644 --- a/src/temps.h +++ b/src/temps.h @@ -61,13 +61,13 @@ public: return xact_temps->back(); } post_t& copy_post(post_t& origin, xact_t& xact, - account_t * account = NULL); + account_t * account = NULL); post_t& create_post(xact_t& xact, account_t * account); post_t& last_post() { return post_temps->back(); } account_t& create_account(const string& name = "", - account_t * parent = NULL); + account_t * parent = NULL); account_t& last_account() { return acct_temps->back(); } diff --git a/src/textual.cc b/src/textual.cc index 85b1a14b..9a4fee8e 100644 --- a/src/textual.cc +++ b/src/textual.cc @@ -49,26 +49,26 @@ namespace ledger { namespace { - typedef std::pair<commodity_t *, amount_t> fixed_rate_t; + typedef std::pair<commodity_t *, amount_t> fixed_rate_t; typedef variant<account_t *, string, fixed_rate_t> state_t; class parse_context_t : public noncopyable { public: - journal_t& journal; - scope_t& scope; + journal_t& journal; + scope_t& scope; std::list<state_t> state_stack; #if defined(TIMELOG_SUPPORT) - time_log_t timelog; + time_log_t timelog; #endif - bool strict; - std::size_t count; - std::size_t errors; - std::size_t sequence; + bool strict; + std::size_t count; + std::size_t errors; + std::size_t sequence; parse_context_t(journal_t& _journal, scope_t& _scope) - : journal(_journal), scope(_scope), timelog(journal), - strict(false), count(0), errors(0), sequence(1) {} + : journal(_journal), scope(_scope), timelog(journal, scope), + strict(false), count(0), errors(0), sequence(1) {} bool front_is_account() { return state_stack.front().type() == typeid(account_t *); @@ -82,8 +82,8 @@ namespace { account_t * top_account() { foreach (state_t& state, state_stack) - if (state.type() == typeid(account_t *)) - return boost::get<account_t *>(state); + if (state.type() == typeid(account_t *)) + return boost::get<account_t *>(state); return NULL; } }; @@ -97,9 +97,9 @@ namespace { instance_t * parent; accounts_map account_aliases; const path * original_file; - path pathname; + path pathname; std::istream& in; - char linebuf[MAX_LINE + 1]; + char linebuf[MAX_LINE + 1]; std::size_t linenum; istream_pos_type line_beg_pos; istream_pos_type curr_pos; @@ -107,9 +107,9 @@ namespace { optional<date_t::year_type> current_year; instance_t(parse_context_t& _context, - std::istream& _in, - const path * _original_file = NULL, - instance_t * _parent = NULL); + std::istream& _in, + const path * _original_file = NULL, + instance_t * _parent = NULL); ~instance_t(); @@ -117,7 +117,7 @@ namespace { std::streamsize read_line(char *& line); bool peek_whitespace_line() { return (in.good() && ! in.eof() && - (in.peek() == ' ' || in.peek() == '\t')); + (in.peek() == ' ' || in.peek() == '\t')); } void read_next_directive(); @@ -148,31 +148,31 @@ namespace { void define_directive(char * line); bool general_directive(char * line); - post_t * parse_post(char * line, - std::streamsize len, - account_t * account, - xact_t * xact, - bool defer_expr = false); + post_t * parse_post(char * line, + std::streamsize len, + account_t * account, + xact_t * xact, + bool defer_expr = false); bool parse_posts(account_t * account, - xact_base_t& xact, - const bool defer_expr = false); + xact_base_t& xact, + const bool defer_expr = false); - xact_t * parse_xact(char * line, - std::streamsize len, - account_t * account); + xact_t * parse_xact(char * line, + std::streamsize len, + account_t * account); virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name); + const string& name); }; - void parse_amount_expr(std::istream& in, - scope_t& scope, - post_t& post, - amount_t& amount, - const parse_flags_t& flags = PARSE_DEFAULT, - const bool defer_expr = false, - optional<expr_t> * amount_expr = NULL) + void parse_amount_expr(std::istream& in, + scope_t& scope, + post_t& post, + amount_t& amount, + const parse_flags_t& flags = PARSE_DEFAULT, + const bool defer_expr = false, + optional<expr_t> * amount_expr = NULL) { expr_t expr(in, flags.plus_flags(PARSE_PARTIAL)); @@ -181,25 +181,25 @@ namespace { #if defined(DEBUG_ENABLED) DEBUG_IF("textual.parse") { if (_debug_stream) { - ledger::dump_value_expr(*_debug_stream, expr); - *_debug_stream << std::endl; + ledger::dump_value_expr(*_debug_stream, expr); + *_debug_stream << std::endl; } } #endif if (expr) { if (amount_expr) - *amount_expr = expr; + *amount_expr = expr; if (! defer_expr) - amount = post.resolve_expr(scope, expr); + amount = post.resolve_expr(scope, expr); } } } instance_t::instance_t(parse_context_t& _context, - std::istream& _in, - const path * _original_file, - instance_t * _parent) + std::istream& _in, + const path * _original_file, + instance_t * _parent) : context(_context), parent(_parent), original_file(_original_file), pathname(original_file ? *original_file : "/dev/stdin"), in(_in) { @@ -216,7 +216,7 @@ void instance_t::parse() INFO("Parsing file '" << pathname.string() << "'"); TRACE_START(instance_parse, 1, - "Done parsing file '" << pathname.string() << "'"); + "Done parsing file '" << pathname.string() << "'"); if (! in.good() || in.eof()) return; @@ -232,30 +232,30 @@ void instance_t::parse() string current_context = error_context(); if (parent) { - std::list<instance_t *> instances; + std::list<instance_t *> instances; - for (instance_t * instance = parent; - instance; - instance = instance->parent) - instances.push_front(instance); + for (instance_t * instance = parent; + instance; + instance = instance->parent) + instances.push_front(instance); - foreach (instance_t * instance, instances) - add_error_context(_("In file included from %1") - << file_context(instance->pathname, - instance->linenum)); + foreach (instance_t * instance, instances) + add_error_context(_("In file included from %1") + << file_context(instance->pathname, + instance->linenum)); } add_error_context(_("While parsing file %1") - << file_context(pathname, linenum)); + << file_context(pathname, linenum)); if (caught_signal != NONE_CAUGHT) - throw; + throw; string err_context = error_context(); if (! err_context.empty()) - std::cerr << err_context << std::endl; + std::cerr << err_context << std::endl; if (! current_context.empty()) - std::cerr << current_context << std::endl; + std::cerr << current_context << std::endl; std::cerr << _("Error: ") << err.what() << std::endl; context.errors++; @@ -268,7 +268,7 @@ void instance_t::parse() std::streamsize instance_t::read_line(char *& line) { assert(in.good()); - assert(! in.eof()); // no one should call us in that case + assert(! in.eof()); // no one should call us in that case line_beg_pos = curr_pos; @@ -283,7 +283,7 @@ std::streamsize instance_t::read_line(char *& line) else line = linebuf; - if (line[len - 1] == '\r') // strip Windows CRLF down to LF + if (line[len - 1] == '\r') // strip Windows CRLF down to LF line[--len] = '\0'; linenum++; @@ -291,7 +291,7 @@ std::streamsize instance_t::read_line(char *& line) curr_pos = line_beg_pos; curr_pos += len; - return len - 1; // LF is being silently dropped + return len - 1; // LF is being silently dropped } return 0; } @@ -306,7 +306,7 @@ void instance_t::read_next_directive() switch (line[0]) { case '\0': - assert(false); // shouldn't ever reach here + assert(false); // shouldn't ever reach here break; case ' ': @@ -314,13 +314,13 @@ void instance_t::read_next_directive() break; } - case ';': // comments + case ';': // comments case '#': case '*': case '|': break; - case '-': // option setting + case '-': // option setting option_directive(line); break; @@ -336,10 +336,10 @@ void instance_t::read_next_directive() case '9': xact_directive(line, len); break; - case '=': // automated xact + case '=': // automated xact automated_xact_directive(line); break; - case '~': // period xact + case '~': // period xact period_xact_directive(line); break; @@ -347,47 +347,47 @@ void instance_t::read_next_directive() case '!': line++; // fall through... - default: // some other directive + default: // some other directive if (! general_directive(line)) { switch (line[0]) { #if defined(TIMELOG_SUPPORT) case 'i': - clock_in_directive(line, false); - break; + clock_in_directive(line, false); + break; case 'I': - clock_in_directive(line, true); - break; + clock_in_directive(line, true); + break; case 'o': - clock_out_directive(line, false); - break; + clock_out_directive(line, false); + break; case 'O': - clock_out_directive(line, true); - break; + clock_out_directive(line, true); + break; case 'h': case 'b': - break; + break; #endif // TIMELOG_SUPPORT - case 'A': // a default account for unbalanced posts - default_account_directive(line); - break; - case 'C': // a set of conversions - price_conversion_directive(line); - break; - case 'D': // a default commodity for "xact" - default_commodity_directive(line); - break; - case 'N': // don't download prices - nomarket_directive(line); - break; - case 'P': // a pricing xact - price_xact_directive(line); - break; - case 'Y': // set the current year - year_directive(line); - break; + case 'A': // a default account for unbalanced posts + default_account_directive(line); + break; + case 'C': // a set of conversions + price_conversion_directive(line); + break; + case 'D': // a default commodity for "xact" + default_commodity_directive(line); + break; + case 'N': // don't download prices + nomarket_directive(line); + break; + case 'P': // a pricing xact + price_xact_directive(line); + break; + case 'Y': // set the current year + year_directive(line); + break; } } break; @@ -418,9 +418,9 @@ void instance_t::clock_in_directive(char * line, bool /*capitalized*/) position.sequence = context.sequence++; time_xact_t event(position, parse_datetime(datetime, current_year), - p ? context.top_account()->find_account(p) : NULL, - n ? n : "", - end ? end : ""); + p ? context.top_account()->find_account(p) : NULL, + n ? n : "", + end ? end : ""); context.timelog.clock_in(event); } @@ -447,9 +447,9 @@ void instance_t::clock_out_directive(char * line, bool /*capitalized*/) position.sequence = context.sequence++; time_xact_t event(position, parse_datetime(datetime, current_year), - p ? context.top_account()->find_account(p) : NULL, - n ? n : "", - end ? end : ""); + p ? context.top_account()->find_account(p) : NULL, + n ? n : "", + end ? end : ""); context.timelog.clock_out(event); context.count++; @@ -526,8 +526,8 @@ void instance_t::automated_xact_directive(char * line) std::auto_ptr<auto_xact_t> ae (new auto_xact_t(query_t(string(skip_ws(line + 1)), - keep_details_t(true, true, true), false))); - ae->pos = position_t(); + keep_details_t(true, true, true), false))); + ae->pos = position_t(); ae->pos->pathname = pathname; ae->pos->beg_pos = line_beg_pos; ae->pos->beg_line = linenum; @@ -540,7 +540,7 @@ void instance_t::automated_xact_directive(char * line) context.journal.auto_xacts.push_back(ae.get()); - ae->journal = &context.journal; + ae->journal = &context.journal; ae->pos->end_pos = curr_pos; ae->pos->end_line = linenum; @@ -610,7 +610,7 @@ void instance_t::xact_directive(char * line, std::streamsize len) std::auto_ptr<xact_t> manager(xact); if (context.journal.add_xact(xact)) { - manager.release(); // it's owned by the journal now + manager.release(); // it's owned by the journal now context.count++; } // It's perfectly valid for the journal to reject the xact, which it will @@ -650,10 +650,10 @@ void instance_t::include_directive(char * line) mask_t glob; #if BOOST_VERSION >= 103700 - path parent_path = filename.parent_path(); + path parent_path = filename.parent_path(); glob.assign_glob(filename.filename()); #else // BOOST_VERSION >= 103700 - path parent_path = filename.branch_path(); + path parent_path = filename.branch_path(); glob.assign_glob(filename.leaf()); #endif // BOOST_VERSION >= 103700 @@ -661,33 +661,33 @@ void instance_t::include_directive(char * line) if (exists(parent_path)) { filesystem::directory_iterator end; for (filesystem::directory_iterator iter(parent_path); - iter != end; - ++iter) { + iter != end; + ++iter) { #if BOOST_VERSION <= 103500 if (is_regular(*iter)) #else if (is_regular_file(*iter)) #endif - { + { #if BOOST_VERSION >= 103700 - string base = (*iter).filename(); + string base = (*iter).filename(); #else // BOOST_VERSION >= 103700 - string base = (*iter).leaf(); + string base = (*iter).leaf(); #endif // BOOST_VERSION >= 103700 - if (glob.match(base)) { - path inner_file(*iter); - ifstream stream(inner_file); - instance_t instance(context, stream, &inner_file, this); - instance.parse(); - files_found = true; - } + if (glob.match(base)) { + path inner_file(*iter); + ifstream stream(inner_file); + instance_t instance(context, stream, &inner_file, this); + instance.parse(); + files_found = true; + } } } } if (! files_found) throw_(std::runtime_error, - _("File to include was not found: '%1'") << filename); + _("File to include was not found: '%1'") << filename); } @@ -707,17 +707,17 @@ void instance_t::end_directive(char * kind) if ((name.empty() || name == "account") && ! context.front_is_account()) throw_(std::runtime_error, - _("'end account' directive does not match open directive")); + _("'end account' directive does not match open directive")); else if (name == "tag" && ! context.front_is_string()) throw_(std::runtime_error, - _("'end tag' directive does not match open directive")); + _("'end tag' directive does not match open directive")); else if (name == "fixed" && ! context.front_is_fixed_rate()) throw_(std::runtime_error, - _("'end fixed' directive does not match open directive")); + _("'end fixed' directive does not match open directive")); if (context.state_stack.size() <= 1) throw_(std::runtime_error, - _("'end' found, but no enclosing tag or account directive")); + _("'end' found, but no enclosing tag or account directive")); else context.state_stack.pop_front(); } @@ -747,9 +747,9 @@ void instance_t::fixed_directive(char * line) { if (optional<std::pair<commodity_t *, price_point_t> > price_point = commodity_pool_t::current_pool->parse_price_directive(trim_ws(line), - true)) { + true)) { context.state_stack.push_front(fixed_rate_t(price_point->first, - price_point->second.price)); + price_point->second.price)); } else { throw_(std::runtime_error, _("Error in fixed directive")); } @@ -789,7 +789,7 @@ void instance_t::account_mapping_directive(char * line) if (payee_regex) context.journal.account_mappings.push_back (account_mapping_t(mask_t(payee_regex), - context.top_account()->find_account(account_name))); + context.top_account()->find_account(account_name))); while (peek_whitespace_line()) { #if defined(NO_ASSERTS) @@ -805,7 +805,7 @@ void instance_t::account_mapping_directive(char * line) context.journal.account_mappings.push_back (account_mapping_t(mask_t(payee_regex), - context.top_account()->find_account(account_name))); + context.top_account()->find_account(account_name))); } } @@ -822,7 +822,7 @@ void instance_t::tag_directive(char * line) void instance_t::define_directive(char * line) { expr_t def(skip_ws(line)); - def.compile(context.scope); // causes definitions to be established + def.compile(context.scope); // causes definitions to be established } bool instance_t::general_directive(char * line) @@ -923,18 +923,18 @@ bool instance_t::general_directive(char * line) return false; } -post_t * instance_t::parse_post(char * line, - std::streamsize len, - account_t * account, - xact_t * xact, - bool defer_expr) +post_t * instance_t::parse_post(char * line, + std::streamsize len, + account_t * account, + xact_t * xact, + bool defer_expr) { TRACE_START(post_details, 1, "Time spent parsing postings:"); std::auto_ptr<post_t> post(new post_t); - post->xact = xact; // this could be NULL - post->pos = position_t(); + post->xact = xact; // this could be NULL + post->pos = position_t(); post->pos->pathname = pathname; post->pos->beg_pos = line_beg_pos; post->pos->beg_line = linenum; @@ -958,14 +958,14 @@ post_t * instance_t::parse_post(char * line, post->set_state(item_t::CLEARED); p = skip_ws(p + 1); DEBUG("textual.parse", "line " << linenum << ": " - << "Parsed the CLEARED flag"); + << "Parsed the CLEARED flag"); break; case '!': post->set_state(item_t::PENDING); p = skip_ws(p + 1); DEBUG("textual.parse", "line " << linenum << ": " - << "Parsed the PENDING flag"); + << "Parsed the PENDING flag"); break; } @@ -988,19 +988,19 @@ post_t * instance_t::parse_post(char * line, if ((*p == '[' && *(e - 1) == ']') || (*p == '(' && *(e - 1) == ')')) { post->add_flags(POST_VIRTUAL); DEBUG("textual.parse", "line " << linenum << ": " - << "Parsed a virtual account name"); + << "Parsed a virtual account name"); if (*p == '[') { post->add_flags(POST_MUST_BALANCE); DEBUG("textual.parse", "line " << linenum << ": " - << "Posting must balance"); + << "Posting must balance"); } p++; e--; } string name(p, e - p); DEBUG("textual.parse", "line " << linenum << ": " - << "Parsed account name " << name); + << "Parsed account name " << name); if (account_aliases.size() > 0) { accounts_map::const_iterator i = account_aliases.find(name); @@ -1013,15 +1013,15 @@ post_t * instance_t::parse_post(char * line, if (context.strict && ! post->account->has_flags(ACCOUNT_KNOWN)) { if (post->_state == item_t::UNCLEARED) warning_(_("\"%1\", line %2: Unknown account '%3'") - << pathname << linenum << post->account->fullname()); + << pathname << linenum << post->account->fullname()); post->account->add_flags(ACCOUNT_KNOWN); } if (post->account->name == _("Unknown")) { foreach (account_mapping_t& value, context.journal.account_mappings) { if (value.first.match(xact->payee)) { - post->account = value.second; - break; + post->account = value.second; + break; } } } @@ -1036,39 +1036,39 @@ post_t * instance_t::parse_post(char * line, beg = next - line; ptristream stream(next, len - beg); - if (*next != '(') // indicates a value expression + if (*next != '(') // indicates a value expression post->amount.parse(stream, PARSE_NO_REDUCE); else parse_amount_expr(stream, context.scope, *post.get(), post->amount, - PARSE_NO_REDUCE | PARSE_SINGLE | PARSE_NO_ASSIGN, - defer_expr, &post->amount_expr); + PARSE_NO_REDUCE | PARSE_SINGLE | PARSE_NO_ASSIGN, + defer_expr, &post->amount_expr); if (! post->amount.is_null() && post->amount.has_commodity()) { if (context.strict && - ! post->amount.commodity().has_flags(COMMODITY_KNOWN)) { - if (post->_state == item_t::UNCLEARED) - warning_(_("\"%1\", line %2: Unknown commodity '%3'") - << pathname << linenum << post->amount.commodity()); - post->amount.commodity().add_flags(COMMODITY_KNOWN); + ! post->amount.commodity().has_flags(COMMODITY_KNOWN)) { + if (post->_state == item_t::UNCLEARED) + warning_(_("\"%1\", line %2: Unknown commodity '%3'") + << pathname << linenum << post->amount.commodity()); + post->amount.commodity().add_flags(COMMODITY_KNOWN); } if (! post->amount.has_annotation()) { - foreach (state_t& state, context.state_stack) { - if (state.type() == typeid(fixed_rate_t)) { - fixed_rate_t& rate(boost::get<fixed_rate_t>(state)); - if (*rate.first == post->amount.commodity()) { - annotation_t details(rate.second); - details.add_flags(ANNOTATION_PRICE_FIXATED); - post->amount.annotate(details); - break; - } - } - } + foreach (state_t& state, context.state_stack) { + if (state.type() == typeid(fixed_rate_t)) { + fixed_rate_t& rate(boost::get<fixed_rate_t>(state)); + if (*rate.first == post->amount.commodity()) { + annotation_t details(rate.second); + details.add_flags(ANNOTATION_PRICE_FIXATED); + post->amount.annotate(details); + break; + } + } + } } } DEBUG("textual.parse", "line " << linenum << ": " - << "post amount = " << post->amount); + << "post amount = " << post->amount); if (stream.eof()) { next = NULL; @@ -1078,62 +1078,73 @@ post_t * instance_t::parse_post(char * line, // Parse the optional cost (@ PER-UNIT-COST, @@ TOTAL-COST) if (*next == '@') { - DEBUG("textual.parse", "line " << linenum << ": " - << "Found a price indicator"); - - bool per_unit = true; - - if (*++next == '@') { - per_unit = false; - post->add_flags(POST_COST_IN_FULL); - DEBUG("textual.parse", "line " << linenum << ": " - << "And it's for a total price"); - } - - beg = ++next - line; - - p = skip_ws(next); - if (*p) { - post->cost = amount_t(); - - beg = p - line; - ptristream cstream(p, len - beg); - - if (*p != '(') // indicates a value expression - post->cost->parse(cstream, PARSE_NO_MIGRATE); - else - parse_amount_expr(cstream, context.scope, *post.get(), *post->cost, - PARSE_NO_MIGRATE | PARSE_SINGLE | PARSE_NO_ASSIGN); - - if (post->cost->sign() < 0) - throw parse_error(_("A posting's cost may not be negative")); - - post->cost->in_place_unround(); - - if (per_unit) { - // For the sole case where the cost might be uncommoditized, - // guarantee that the commodity of the cost after multiplication - // is the same as it was before. - commodity_t& cost_commodity(post->cost->commodity()); - *post->cost *= post->amount; - post->cost->set_commodity(cost_commodity); - } - else if (post->amount.sign() < 0) { - post->cost->in_place_negate(); - } - - DEBUG("textual.parse", "line " << linenum << ": " - << "Total cost is " << *post->cost); - DEBUG("textual.parse", "line " << linenum << ": " - << "Annotated amount is " << post->amount); - - if (cstream.eof()) - next = NULL; - else - next = skip_ws(p + static_cast<std::ptrdiff_t>(cstream.tellg())); - } else { - throw parse_error(_("Expected a cost amount")); - } + DEBUG("textual.parse", "line " << linenum << ": " + << "Found a price indicator"); + + bool per_unit = true; + + if (*++next == '@') { + per_unit = false; + post->add_flags(POST_COST_IN_FULL); + DEBUG("textual.parse", "line " << linenum << ": " + << "And it's for a total price"); + } + + beg = ++next - line; + + p = skip_ws(next); + if (*p) { + post->cost = amount_t(); + + bool fixed_cost = false; + if (*p == '=') { + p++; + fixed_cost = true; + if (*p == '\0') + throw parse_error(_("Posting is missing a cost amount")); + } + + beg = p - line; + ptristream cstream(p, len - beg); + + if (*p != '(') // indicates a value expression + post->cost->parse(cstream, PARSE_NO_MIGRATE); + else + parse_amount_expr(cstream, context.scope, *post.get(), *post->cost, + PARSE_NO_MIGRATE | PARSE_SINGLE | PARSE_NO_ASSIGN); + + if (post->cost->sign() < 0) + throw parse_error(_("A posting's cost may not be negative")); + + post->cost->in_place_unround(); + + if (per_unit) { + // For the sole case where the cost might be uncommoditized, + // guarantee that the commodity of the cost after multiplication + // is the same as it was before. + commodity_t& cost_commodity(post->cost->commodity()); + *post->cost *= post->amount; + post->cost->set_commodity(cost_commodity); + } + else if (post->amount.sign() < 0) { + post->cost->in_place_negate(); + } + + if (fixed_cost) + post->add_flags(POST_COST_FIXATED); + + DEBUG("textual.parse", "line " << linenum << ": " + << "Total cost is " << *post->cost); + DEBUG("textual.parse", "line " << linenum << ": " + << "Annotated amount is " << post->amount); + + if (cstream.eof()) + next = NULL; + else + next = skip_ws(p + static_cast<std::ptrdiff_t>(cstream.tellg())); + } else { + throw parse_error(_("Expected a cost amount")); + } } } } @@ -1142,7 +1153,7 @@ post_t * instance_t::parse_post(char * line, if (xact && next && *next == '=') { DEBUG("textual.parse", "line " << linenum << ": " - << "Found a balance assignment indicator"); + << "Found a balance assignment indicator"); beg = ++next - line; @@ -1153,70 +1164,70 @@ post_t * instance_t::parse_post(char * line, beg = p - line; ptristream stream(p, len - beg); - if (*p != '(') // indicates a value expression - post->assigned_amount->parse(stream, PARSE_NO_MIGRATE); + if (*p != '(') // indicates a value expression + post->assigned_amount->parse(stream, PARSE_NO_MIGRATE); else - parse_amount_expr(stream, context.scope, *post.get(), - *post->assigned_amount, - PARSE_SINGLE | PARSE_NO_MIGRATE); + parse_amount_expr(stream, context.scope, *post.get(), + *post->assigned_amount, + PARSE_SINGLE | PARSE_NO_MIGRATE); if (post->assigned_amount->is_null()) { - if (post->amount.is_null()) - throw parse_error(_("Balance assignment must evaluate to a constant")); - else - throw parse_error(_("Balance assertion must evaluate to a constant")); + if (post->amount.is_null()) + throw parse_error(_("Balance assignment must evaluate to a constant")); + else + throw parse_error(_("Balance assertion must evaluate to a constant")); } DEBUG("textual.parse", "line " << linenum << ": " - << "POST assign: parsed amt = " << *post->assigned_amount); + << "POST assign: parsed amt = " << *post->assigned_amount); - amount_t& amt(*post->assigned_amount); + amount_t& amt(*post->assigned_amount); value_t account_total - (post->account->amount(false).strip_annotations(keep_details_t())); + (post->account->amount(false).strip_annotations(keep_details_t())); DEBUG("post.assign", - "line " << linenum << ": " "account balance = " << account_total); + "line " << linenum << ": " "account balance = " << account_total); DEBUG("post.assign", - "line " << linenum << ": " "post amount = " << amt); + "line " << linenum << ": " "post amount = " << amt); amount_t diff = amt; switch (account_total.type()) { case value_t::AMOUNT: - diff -= account_total.as_amount(); - break; + diff -= account_total.as_amount(); + break; case value_t::BALANCE: - if (optional<amount_t> comm_bal = - account_total.as_balance().commodity_amount(amt.commodity())) - diff -= *comm_bal; - break; + if (optional<amount_t> comm_bal = + account_total.as_balance().commodity_amount(amt.commodity())) + diff -= *comm_bal; + break; default: - break; + break; } DEBUG("post.assign", - "line " << linenum << ": " << "diff = " << diff); + "line " << linenum << ": " << "diff = " << diff); DEBUG("textual.parse", - "line " << linenum << ": " << "POST assign: diff = " << diff); + "line " << linenum << ": " << "POST assign: diff = " << diff); if (! diff.is_zero()) { - if (! post->amount.is_null()) { - diff -= post->amount; - if (! diff.is_zero()) - throw_(parse_error, _("Balance assertion off by %1") << diff); - } else { - post->amount = diff; - DEBUG("textual.parse", "line " << linenum << ": " - << "Overwrite null posting"); - } + if (! post->amount.is_null()) { + diff -= post->amount; + if (! diff.is_zero()) + throw_(parse_error, _("Balance assertion off by %1") << diff); + } else { + post->amount = diff; + DEBUG("textual.parse", "line " << linenum << ": " + << "Overwrite null posting"); + } } if (stream.eof()) - next = NULL; + next = NULL; else - next = skip_ws(p + static_cast<std::ptrdiff_t>(stream.tellg())); + next = skip_ws(p + static_cast<std::ptrdiff_t>(stream.tellg())); } else { throw parse_error(_("Expected an balance assignment/assertion amount")); } @@ -1225,18 +1236,18 @@ post_t * instance_t::parse_post(char * line, // Parse the optional note if (next && *next == ';') { - post->append_note(++next, true, current_year); + post->append_note(++next, context.scope, true, current_year); next = line + len; DEBUG("textual.parse", "line " << linenum << ": " - << "Parsed a posting note"); + << "Parsed a posting note"); } // There should be nothing more to read if (next && *next) throw_(parse_error, - _("Unexpected char '%1' (Note: inline math requires parentheses)") - << *next); + _("Unexpected char '%1' (Note: inline math requires parentheses)") + << *next); post->pos->end_pos = curr_pos; post->pos->end_line = linenum; @@ -1244,7 +1255,8 @@ post_t * instance_t::parse_post(char * line, if (! context.state_stack.empty()) { foreach (const state_t& state, context.state_stack) if (state.type() == typeid(string)) - post->parse_tags(boost::get<string>(state).c_str(), true); + post->parse_tags(boost::get<string>(state).c_str(), context.scope, + true); } TRACE_STOP(post_details, 1); @@ -1260,8 +1272,8 @@ post_t * instance_t::parse_post(char * line, } bool instance_t::parse_posts(account_t * account, - xact_base_t& xact, - const bool defer_expr) + xact_base_t& xact, + const bool defer_expr) { TRACE_START(xact_posts, 1, "Time spent parsing postings:"); @@ -1283,15 +1295,15 @@ bool instance_t::parse_posts(account_t * account, return added; } -xact_t * instance_t::parse_xact(char * line, - std::streamsize len, - account_t * account) +xact_t * instance_t::parse_xact(char * line, + std::streamsize len, + account_t * account) { TRACE_START(xact_text, 1, "Time spent parsing transaction text:"); std::auto_ptr<xact_t> xact(new xact_t); - xact->pos = position_t(); + xact->pos = position_t(); xact->pos->pathname = pathname; xact->pos->beg_pos = line_beg_pos; xact->pos->beg_line = linenum; @@ -1342,8 +1354,8 @@ xact_t * instance_t::parse_xact(char * line, char * p = next_element(next, true); foreach (payee_mapping_t& value, context.journal.payee_mappings) { if (value.first.match(next)) { - xact->payee = value.second; - break; + xact->payee = value.second; + break; } } if (xact->payee.empty()) @@ -1356,7 +1368,7 @@ xact_t * instance_t::parse_xact(char * line, // Parse the xact note if (next && *next == ';') - xact->append_note(++next, current_year); + xact->append_note(++next, context.scope, false, current_year); TRACE_STOP(xact_text, 1); @@ -1376,21 +1388,21 @@ xact_t * instance_t::parse_xact(char * line, if (*p == ';') { item_t * item; if (last_post) - item = last_post; + item = last_post; else - item = xact.get(); + item = xact.get(); // This is a trailing note, and possibly a metadata info tag - item->append_note(p + 1, true, current_year); + item->append_note(p + 1, context.scope, true, current_year); item->pos->end_pos = curr_pos; item->pos->end_line++; } else { reveal_context = false; if (post_t * post = - parse_post(p, len - (p - line), account, xact.get())) { - xact->add_post(post); - last_post = post; + parse_post(p, len - (p - line), account, xact.get())) { + xact->add_post(post); + last_post = post; } } } @@ -1400,11 +1412,11 @@ xact_t * instance_t::parse_xact(char * line, foreach (post_t * post, xact->posts) { if (post->_state == item_t::UNCLEARED) { - result = item_t::UNCLEARED; - break; + result = item_t::UNCLEARED; + break; } else if (post->_state == item_t::PENDING) { - result = item_t::PENDING; + result = item_t::PENDING; } } } @@ -1415,7 +1427,8 @@ xact_t * instance_t::parse_xact(char * line, if (! context.state_stack.empty()) { foreach (const state_t& state, context.state_stack) if (state.type() == typeid(string)) - xact->parse_tags(boost::get<string>(state).c_str(), false); + xact->parse_tags(boost::get<string>(state).c_str(), context.scope, + false); } TRACE_STOP(xact_details, 1); @@ -1427,23 +1440,23 @@ xact_t * instance_t::parse_xact(char * line, if (reveal_context) { add_error_context(_("While parsing transaction:")); add_error_context(source_context(xact->pos->pathname, - xact->pos->beg_pos, curr_pos, "> ")); + xact->pos->beg_pos, curr_pos, "> ")); } throw; } } expr_t::ptr_op_t instance_t::lookup(const symbol_t::kind_t kind, - const string& name) + const string& name) { return context.scope.lookup(kind, name); } std::size_t journal_t::parse(std::istream& in, - scope_t& scope, - account_t * master, - const path * original_file, - bool strict) + scope_t& scope, + account_t * master, + const path * original_file, + bool strict) { TRACE_START(parsing_total, 1, "Total time spent parsing text:"); diff --git a/src/timelog.cc b/src/timelog.cc index 217aa581..698e2420 100644 --- a/src/timelog.cc +++ b/src/timelog.cc @@ -41,8 +41,9 @@ namespace ledger { namespace { void clock_out_from_timelog(std::list<time_xact_t>& time_xacts, - time_xact_t out_event, - journal_t& journal) + time_xact_t out_event, + journal_t& journal, + scope_t& scope) { time_xact_t event; @@ -55,29 +56,29 @@ namespace { } else if (! out_event.account) { throw parse_error - (_("When multiple check-ins are active, checking out requires an account")); + (_("When multiple check-ins are active, checking out requires an account")); } else { bool found = false; for (std::list<time_xact_t>::iterator i = time_xacts.begin(); - i != time_xacts.end(); - i++) - if (out_event.account == (*i).account) { - event = *i; - found = true; - time_xacts.erase(i); - break; - } + i != time_xacts.end(); + i++) + if (out_event.account == (*i).account) { + event = *i; + found = true; + time_xacts.erase(i); + break; + } if (! found) - throw parse_error - (_("Timelog check-out event does not match any current check-ins")); + throw parse_error + (_("Timelog check-out event does not match any current check-ins")); } if (out_event.checkin < event.checkin) throw parse_error - (_("Timelog check-out date less than corresponding check-in")); + (_("Timelog check-out date less than corresponding check-in")); if (! out_event.desc.empty() && event.desc.empty()) { event.desc = out_event.desc; @@ -94,11 +95,11 @@ namespace { curr->pos = event.position; if (! event.note.empty()) - curr->append_note(event.note.c_str()); + curr->append_note(event.note.c_str(), scope); char buf[32]; std::sprintf(buf, "%lds", long((out_event.checkin - event.checkin) - .total_seconds())); + .total_seconds())); amount_t amt; amt.parse(buf); VERIFY(amt.valid()); @@ -128,8 +129,8 @@ time_log_t::~time_log_t() foreach (account_t * account, accounts) clock_out_from_timelog(time_xacts, - time_xact_t(none, CURRENT_TIME(), account), - journal); + time_xact_t(none, CURRENT_TIME(), account), + journal, scope); assert(time_xacts.empty()); } @@ -140,7 +141,7 @@ void time_log_t::clock_in(time_xact_t event) if (! time_xacts.empty()) { foreach (time_xact_t& time_xact, time_xacts) { if (event.account == time_xact.account) - throw parse_error(_("Cannot double check-in to the same account")); + throw parse_error(_("Cannot double check-in to the same account")); } } @@ -152,7 +153,7 @@ void time_log_t::clock_out(time_xact_t event) if (time_xacts.empty()) throw std::logic_error(_("Timelog check-out event without a check-in")); - clock_out_from_timelog(time_xacts, event, journal); + clock_out_from_timelog(time_xacts, event, journal, scope); } } // namespace ledger diff --git a/src/timelog.h b/src/timelog.h index caa23ec0..92b80edc 100644 --- a/src/timelog.h +++ b/src/timelog.h @@ -64,14 +64,14 @@ public: TRACE_CTOR(time_xact_t, ""); } time_xact_t(const optional<position_t>& _position, - const datetime_t& _checkin, - account_t * _account = NULL, - const string& _desc = "", - const string& _note = "") + const datetime_t& _checkin, + account_t * _account = NULL, + const string& _desc = "", + const string& _note = "") : checkin(_checkin), account(_account), desc(_desc), note(_note), position(_position ? *_position : position_t()) { TRACE_CTOR(time_xact_t, - "position_t, datetime_t, account_t *, string, string"); + "position_t, datetime_t, account_t *, string, string"); } time_xact_t(const time_xact_t& xact) : checkin(xact.checkin), account(xact.account), @@ -86,11 +86,13 @@ public: class time_log_t { std::list<time_xact_t> time_xacts; - journal_t& journal; + journal_t& journal; + scope_t& scope; public: - time_log_t(journal_t& _journal) : journal(_journal) { - TRACE_CTOR(time_log_t, "journal_t&"); + time_log_t(journal_t& _journal, scope_t& _scope) + : journal(_journal), scope(_scope) { + TRACE_CTOR(time_log_t, "journal_t&, scope_t&"); } ~time_log_t(); diff --git a/src/times.cc b/src/times.cc index 60e8e7cc..26e1dc21 100644 --- a/src/times.cc +++ b/src/times.cc @@ -60,17 +60,17 @@ namespace { temporal_io_t(const char * _fmt_str, bool _input) : fmt_str(_fmt_str), - traits(icontains(fmt_str, "%y"), - icontains(fmt_str, "%m") || icontains(fmt_str, "%b"), - icontains(fmt_str, "%d")), - input(_input) { + traits(icontains(fmt_str, "%y"), + icontains(fmt_str, "%m") || icontains(fmt_str, "%b"), + icontains(fmt_str, "%d")), + input(_input) { #if defined(USE_BOOST_FACETS) if (input) { - input_facet = new InputFacetType(fmt_str); - input_stream.imbue(std::locale(std::locale::classic(), input_facet)); + input_facet = new InputFacetType(fmt_str); + input_stream.imbue(std::locale(std::locale::classic(), input_facet)); } else { - output_facet = new OutputFacetType(fmt_str); - output_stream.imbue(std::locale(std::locale::classic(), output_facet)); + output_facet = new OutputFacetType(fmt_str); + output_stream.imbue(std::locale(std::locale::classic(), output_facet)); } #endif // USE_BOOST_FACETS } @@ -78,14 +78,14 @@ namespace { void set_format(const char * fmt) { fmt_str = fmt; traits = date_traits_t(icontains(fmt_str, "%y"), - icontains(fmt_str, "%m") || - icontains(fmt_str, "%b"), - icontains(fmt_str, "%d")); + icontains(fmt_str, "%m") || + icontains(fmt_str, "%b"), + icontains(fmt_str, "%d")); #if defined(USE_BOOST_FACETS) if (input) - input_facet->format(fmt_str); + input_facet->format(fmt_str); else - output_facet->format(fmt_str); + output_facet->format(fmt_str); #endif // USE_BOOST_FACETS } @@ -110,7 +110,7 @@ namespace { template <> datetime_t temporal_io_t<datetime_t, posix_time::time_input_facet, - posix_time::time_facet> + posix_time::time_facet> ::parse(const char * str) { #if defined(USE_BOOST_FACETS) @@ -122,15 +122,15 @@ namespace { input_stream >> when; #if defined(DEBUG_ON) if (when.is_not_a_date_time()) - DEBUG("times.parse", "Failed to parse date/time '" << str - << "' using pattern '" << fmt_str << "'"); + DEBUG("times.parse", "Failed to parse date/time '" << str + << "' using pattern '" << fmt_str << "'"); #endif if (! when.is_not_a_date_time() && - input_stream.good() && ! input_stream.eof() && - input_stream.peek() != EOF) { - DEBUG("times.parse", "This string has leftovers: '" << str << "'"); - return datetime_t(); + input_stream.good() && ! input_stream.eof() && + input_stream.peek() != EOF) { + DEBUG("times.parse", "This string has leftovers: '" << str << "'"); + return datetime_t(); } return when; #else // USE_BOOST_FACETS @@ -145,7 +145,7 @@ namespace { template <> date_t temporal_io_t<date_t, gregorian::date_input_facet, - gregorian::date_facet> + gregorian::date_facet> ::parse(const char * str) { #if defined(USE_BOOST_FACETS) @@ -157,21 +157,21 @@ namespace { input_stream >> when; #if defined(DEBUG_ON) if (when.is_not_a_date()) - DEBUG("times.parse", "Failed to parse date '" << str - << "' using pattern '" << fmt_str << "'"); + DEBUG("times.parse", "Failed to parse date '" << str + << "' using pattern '" << fmt_str << "'"); #endif if (! when.is_not_a_date() && - input_stream.good() && ! input_stream.eof() && - input_stream.peek() != EOF) { - DEBUG("times.parse", "This string has leftovers: '" << str << "'"); - return date_t(); + input_stream.good() && ! input_stream.eof() && + input_stream.peek() != EOF) { + DEBUG("times.parse", "This string has leftovers: '" << str << "'"); + return date_t(); } return when; #else // USE_BOOST_FACETS std::tm data; std::memset(&data, 0, sizeof(std::tm)); - data.tm_mday = 1; // some formats have no day + data.tm_mday = 1; // some formats have no day if (strptime(str, fmt_str, &data)) return gregorian::date_from_tm(data); else @@ -180,9 +180,9 @@ namespace { } typedef temporal_io_t<datetime_t, posix_time::time_input_facet, - posix_time::time_facet> datetime_io_t; + posix_time::time_facet> datetime_io_t; typedef temporal_io_t<date_t, gregorian::date_input_facet, - gregorian::date_facet> date_io_t; + gregorian::date_facet> date_io_t; shared_ptr<datetime_io_t> input_datetime_io; shared_ptr<date_io_t> input_date_io; @@ -194,8 +194,8 @@ namespace { std::vector<shared_ptr<date_io_t> > readers; date_t parse_date_mask_routine(const char * date_str, date_io_t& io, - optional_year year, - date_traits_t * traits = NULL) + optional_year year, + date_traits_t * traits = NULL) { VERIFY(std::strlen(date_str) < 127); @@ -204,7 +204,7 @@ namespace { for (char * p = buf; *p; p++) if (*p == '.' || *p == '-') - *p = '/'; + *p = '/'; date_t when = io.parse(buf); @@ -219,41 +219,41 @@ namespace { const char * p = when_str.c_str(); const char * q = buf; for (; *p && *q; p++, q++) { - if (*p != *q && *p == '0') p++; - if (! *p || *p != *q) break; + if (*p != *q && *p == '0') p++; + if (! *p || *p != *q) break; } if (*p != '\0' || *q != '\0') - throw_(date_error, _("Invalid date: %1") << date_str); + throw_(date_error, _("Invalid date: %1") << date_str); if (traits) - *traits = io.traits; + *traits = io.traits; if (! io.traits.has_year) { - when = date_t(year ? *year : CURRENT_DATE().year(), - when.month(), when.day()); + when = date_t(year ? *year : CURRENT_DATE().year(), + when.month(), when.day()); - if (! year && when.month() > CURRENT_DATE().month()) - when -= gregorian::years(1); + if (! year && when.month() > CURRENT_DATE().month()) + when -= gregorian::years(1); } } return when; } date_t parse_date_mask(const char * date_str, optional_year year, - date_traits_t * traits = NULL) + date_traits_t * traits = NULL) { if (input_date_io.get()) { date_t when = parse_date_mask_routine(date_str, *input_date_io.get(), - year, traits); + year, traits); if (! when.is_not_a_date()) - return when; + return when; } foreach (shared_ptr<date_io_t>& reader, readers) { date_t when = parse_date_mask_routine(date_str, *reader.get(), - year, traits); + year, traits); if (! when.is_not_a_date()) - return when; + return when; } throw_(date_error, _("Invalid date: %1") << date_str); @@ -344,8 +344,8 @@ date_t date_specifier_t::begin(const optional_year& current_year) const // wday in that month; if the year is set, then in that year. return gregorian::date(static_cast<date_t::year_type>(the_year), - static_cast<date_t::month_type>(the_month), - static_cast<date_t::day_type>(the_day)); + static_cast<date_t::month_type>(the_month), + static_cast<date_t::day_type>(the_day)); } date_t date_specifier_t::end(const optional_year& current_year) const @@ -363,7 +363,7 @@ date_t date_specifier_t::end(const optional_year& current_year) const } std::ostream& operator<<(std::ostream& out, - const date_duration_t& duration) + const date_duration_t& duration) { if (duration.quantum == date_duration_t::DAYS) out << duration.length << " day(s)"; @@ -395,194 +395,194 @@ class date_parser_t struct token_t { enum kind_t { - UNKNOWN, - - TOK_DATE, - TOK_INT, - TOK_SLASH, - TOK_DASH, - TOK_DOT, - - TOK_A_YEAR, - TOK_A_MONTH, - TOK_A_WDAY, - - TOK_SINCE, - TOK_UNTIL, - TOK_IN, - TOK_THIS, - TOK_NEXT, - TOK_LAST, - TOK_EVERY, - - TOK_TODAY, - TOK_TOMORROW, - TOK_YESTERDAY, - - TOK_YEAR, - TOK_QUARTER, - TOK_MONTH, - TOK_WEEK, - TOK_DAY, - - TOK_YEARLY, - TOK_QUARTERLY, - TOK_BIMONTHLY, - TOK_MONTHLY, - TOK_BIWEEKLY, - TOK_WEEKLY, - TOK_DAILY, - - TOK_YEARS, - TOK_QUARTERS, - TOK_MONTHS, - TOK_WEEKS, - TOK_DAYS, - - END_REACHED + UNKNOWN, + + TOK_DATE, + TOK_INT, + TOK_SLASH, + TOK_DASH, + TOK_DOT, + + TOK_A_YEAR, + TOK_A_MONTH, + TOK_A_WDAY, + + TOK_SINCE, + TOK_UNTIL, + TOK_IN, + TOK_THIS, + TOK_NEXT, + TOK_LAST, + TOK_EVERY, + + TOK_TODAY, + TOK_TOMORROW, + TOK_YESTERDAY, + + TOK_YEAR, + TOK_QUARTER, + TOK_MONTH, + TOK_WEEK, + TOK_DAY, + + TOK_YEARLY, + TOK_QUARTERLY, + TOK_BIMONTHLY, + TOK_MONTHLY, + TOK_BIWEEKLY, + TOK_WEEKLY, + TOK_DAILY, + + TOK_YEARS, + TOK_QUARTERS, + TOK_MONTHS, + TOK_WEEKS, + TOK_DAYS, + + END_REACHED } kind; typedef variant<unsigned short, - string, - date_specifier_t::year_type, - date_time::months_of_year, - date_time::weekdays, - date_specifier_t> content_t; + string, + date_specifier_t::year_type, + date_time::months_of_year, + date_time::weekdays, + date_specifier_t> content_t; optional<content_t> value; explicit token_t(kind_t _kind = UNKNOWN, - const optional<content_t>& _value = - content_t(empty_string)) - : kind(_kind), value(_value) { - TRACE_CTOR(date_parser_t::lexer_t::token_t, ""); + const optional<content_t>& _value = + content_t(empty_string)) + : kind(_kind), value(_value) { + TRACE_CTOR(date_parser_t::lexer_t::token_t, ""); } token_t(const token_t& tok) - : kind(tok.kind), value(tok.value) { - TRACE_CTOR(date_parser_t::lexer_t::token_t, "copy"); + : kind(tok.kind), value(tok.value) { + TRACE_CTOR(date_parser_t::lexer_t::token_t, "copy"); } ~token_t() throw() { - TRACE_DTOR(date_parser_t::lexer_t::token_t); + TRACE_DTOR(date_parser_t::lexer_t::token_t); } token_t& operator=(const token_t& tok) { - if (this != &tok) { - kind = tok.kind; - value = tok.value; - } - return *this; + if (this != &tok) { + kind = tok.kind; + value = tok.value; + } + return *this; } operator bool() const { - return kind != END_REACHED; + return kind != END_REACHED; } string to_string() const { - std::ostringstream out; - - switch (kind) { - case UNKNOWN: - out << boost::get<string>(*value); - break; - case TOK_DATE: - return boost::get<date_specifier_t>(*value).to_string(); - case TOK_INT: - out << boost::get<unsigned short>(*value); - break; - case TOK_SLASH: return "/"; - case TOK_DASH: return "-"; - case TOK_DOT: return "."; - case TOK_A_YEAR: - out << boost::get<date_specifier_t::year_type>(*value); - break; - case TOK_A_MONTH: - out << date_specifier_t::month_type - (boost::get<date_time::months_of_year>(*value)); - break; - case TOK_A_WDAY: - out << date_specifier_t::day_of_week_type - (boost::get<date_time::weekdays>(*value)); - break; - case TOK_SINCE: return "since"; - case TOK_UNTIL: return "until"; - case TOK_IN: return "in"; - case TOK_THIS: return "this"; - case TOK_NEXT: return "next"; - case TOK_LAST: return "last"; - case TOK_EVERY: return "every"; - case TOK_TODAY: return "today"; - case TOK_TOMORROW: return "tomorrow"; - case TOK_YESTERDAY: return "yesterday"; - case TOK_YEAR: return "year"; - case TOK_QUARTER: return "quarter"; - case TOK_MONTH: return "month"; - case TOK_WEEK: return "week"; - case TOK_DAY: return "day"; - case TOK_YEARLY: return "yearly"; - case TOK_QUARTERLY: return "quarterly"; - case TOK_BIMONTHLY: return "bimonthly"; - case TOK_MONTHLY: return "monthly"; - case TOK_BIWEEKLY: return "biweekly"; - case TOK_WEEKLY: return "weekly"; - case TOK_DAILY: return "daily"; - case TOK_YEARS: return "years"; - case TOK_QUARTERS: return "quarters"; - case TOK_MONTHS: return "months"; - case TOK_WEEKS: return "weeks"; - case TOK_DAYS: return "days"; - case END_REACHED: return "<EOF>"; - default: - assert(false); - return empty_string; - } - - return out.str(); + std::ostringstream out; + + switch (kind) { + case UNKNOWN: + out << boost::get<string>(*value); + break; + case TOK_DATE: + return boost::get<date_specifier_t>(*value).to_string(); + case TOK_INT: + out << boost::get<unsigned short>(*value); + break; + case TOK_SLASH: return "/"; + case TOK_DASH: return "-"; + case TOK_DOT: return "."; + case TOK_A_YEAR: + out << boost::get<date_specifier_t::year_type>(*value); + break; + case TOK_A_MONTH: + out << date_specifier_t::month_type + (boost::get<date_time::months_of_year>(*value)); + break; + case TOK_A_WDAY: + out << date_specifier_t::day_of_week_type + (boost::get<date_time::weekdays>(*value)); + break; + case TOK_SINCE: return "since"; + case TOK_UNTIL: return "until"; + case TOK_IN: return "in"; + case TOK_THIS: return "this"; + case TOK_NEXT: return "next"; + case TOK_LAST: return "last"; + case TOK_EVERY: return "every"; + case TOK_TODAY: return "today"; + case TOK_TOMORROW: return "tomorrow"; + case TOK_YESTERDAY: return "yesterday"; + case TOK_YEAR: return "year"; + case TOK_QUARTER: return "quarter"; + case TOK_MONTH: return "month"; + case TOK_WEEK: return "week"; + case TOK_DAY: return "day"; + case TOK_YEARLY: return "yearly"; + case TOK_QUARTERLY: return "quarterly"; + case TOK_BIMONTHLY: return "bimonthly"; + case TOK_MONTHLY: return "monthly"; + case TOK_BIWEEKLY: return "biweekly"; + case TOK_WEEKLY: return "weekly"; + case TOK_DAILY: return "daily"; + case TOK_YEARS: return "years"; + case TOK_QUARTERS: return "quarters"; + case TOK_MONTHS: return "months"; + case TOK_WEEKS: return "weeks"; + case TOK_DAYS: return "days"; + case END_REACHED: return "<EOF>"; + default: + assert(false); + return empty_string; + } + + return out.str(); } void dump(std::ostream& out) const { - switch (kind) { - case UNKNOWN: out << "UNKNOWN"; break; - case TOK_DATE: out << "TOK_DATE"; break; - case TOK_INT: out << "TOK_INT"; break; - case TOK_SLASH: out << "TOK_SLASH"; break; - case TOK_DASH: out << "TOK_DASH"; break; - case TOK_DOT: out << "TOK_DOT"; break; - case TOK_A_YEAR: out << "TOK_A_YEAR"; break; - case TOK_A_MONTH: out << "TOK_A_MONTH"; break; - case TOK_A_WDAY: out << "TOK_A_WDAY"; break; - case TOK_SINCE: out << "TOK_SINCE"; break; - case TOK_UNTIL: out << "TOK_UNTIL"; break; - case TOK_IN: out << "TOK_IN"; break; - case TOK_THIS: out << "TOK_THIS"; break; - case TOK_NEXT: out << "TOK_NEXT"; break; - case TOK_LAST: out << "TOK_LAST"; break; - case TOK_EVERY: out << "TOK_EVERY"; break; - case TOK_TODAY: out << "TOK_TODAY"; break; - case TOK_TOMORROW: out << "TOK_TOMORROW"; break; - case TOK_YESTERDAY: out << "TOK_YESTERDAY"; break; - case TOK_YEAR: out << "TOK_YEAR"; break; - case TOK_QUARTER: out << "TOK_QUARTER"; break; - case TOK_MONTH: out << "TOK_MONTH"; break; - case TOK_WEEK: out << "TOK_WEEK"; break; - case TOK_DAY: out << "TOK_DAY"; break; - case TOK_YEARLY: out << "TOK_YEARLY"; break; - case TOK_QUARTERLY: out << "TOK_QUARTERLY"; break; - case TOK_BIMONTHLY: out << "TOK_BIMONTHLY"; break; - case TOK_MONTHLY: out << "TOK_MONTHLY"; break; - case TOK_BIWEEKLY: out << "TOK_BIWEEKLY"; break; - case TOK_WEEKLY: out << "TOK_WEEKLY"; break; - case TOK_DAILY: out << "TOK_DAILY"; break; - case TOK_YEARS: out << "TOK_YEARS"; break; - case TOK_QUARTERS: out << "TOK_QUARTERS"; break; - case TOK_MONTHS: out << "TOK_MONTHS"; break; - case TOK_WEEKS: out << "TOK_WEEKS"; break; - case TOK_DAYS: out << "TOK_DAYS"; break; - case END_REACHED: out << "END_REACHED"; break; - default: - assert(false); - break; - } + switch (kind) { + case UNKNOWN: out << "UNKNOWN"; break; + case TOK_DATE: out << "TOK_DATE"; break; + case TOK_INT: out << "TOK_INT"; break; + case TOK_SLASH: out << "TOK_SLASH"; break; + case TOK_DASH: out << "TOK_DASH"; break; + case TOK_DOT: out << "TOK_DOT"; break; + case TOK_A_YEAR: out << "TOK_A_YEAR"; break; + case TOK_A_MONTH: out << "TOK_A_MONTH"; break; + case TOK_A_WDAY: out << "TOK_A_WDAY"; break; + case TOK_SINCE: out << "TOK_SINCE"; break; + case TOK_UNTIL: out << "TOK_UNTIL"; break; + case TOK_IN: out << "TOK_IN"; break; + case TOK_THIS: out << "TOK_THIS"; break; + case TOK_NEXT: out << "TOK_NEXT"; break; + case TOK_LAST: out << "TOK_LAST"; break; + case TOK_EVERY: out << "TOK_EVERY"; break; + case TOK_TODAY: out << "TOK_TODAY"; break; + case TOK_TOMORROW: out << "TOK_TOMORROW"; break; + case TOK_YESTERDAY: out << "TOK_YESTERDAY"; break; + case TOK_YEAR: out << "TOK_YEAR"; break; + case TOK_QUARTER: out << "TOK_QUARTER"; break; + case TOK_MONTH: out << "TOK_MONTH"; break; + case TOK_WEEK: out << "TOK_WEEK"; break; + case TOK_DAY: out << "TOK_DAY"; break; + case TOK_YEARLY: out << "TOK_YEARLY"; break; + case TOK_QUARTERLY: out << "TOK_QUARTERLY"; break; + case TOK_BIMONTHLY: out << "TOK_BIMONTHLY"; break; + case TOK_MONTHLY: out << "TOK_MONTHLY"; break; + case TOK_BIWEEKLY: out << "TOK_BIWEEKLY"; break; + case TOK_WEEKLY: out << "TOK_WEEKLY"; break; + case TOK_DAILY: out << "TOK_DAILY"; break; + case TOK_YEARS: out << "TOK_YEARS"; break; + case TOK_QUARTERS: out << "TOK_QUARTERS"; break; + case TOK_MONTHS: out << "TOK_MONTHS"; break; + case TOK_WEEKS: out << "TOK_WEEKS"; break; + case TOK_DAYS: out << "TOK_DAYS"; break; + case END_REACHED: out << "END_REACHED"; break; + default: + assert(false); + break; + } } void unexpected(); @@ -592,14 +592,14 @@ class date_parser_t token_t token_cache; lexer_t(string::const_iterator _begin, - string::const_iterator _end) + string::const_iterator _end) : begin(_begin), end(_end) { TRACE_CTOR(date_parser_t::lexer_t, ""); } lexer_t(const lexer_t& lexer) : begin(lexer.begin), end(lexer.end), - token_cache(lexer.token_cache) + token_cache(lexer.token_cache) { TRACE_CTOR(date_parser_t::lexer_t, "copy"); } @@ -614,7 +614,7 @@ class date_parser_t } token_t peek_token() { if (token_cache.kind == token_t::UNKNOWN) - token_cache = next_token(); + token_cache = next_token(); return token_cache; } }; @@ -642,7 +642,7 @@ private: }; void date_parser_t::determine_when(date_parser_t::lexer_t::token_t& tok, - date_specifier_t& specifier) + date_specifier_t& specifier) { switch (tok.kind) { case lexer_t::token_t::TOK_DATE: @@ -680,8 +680,8 @@ date_interval_t date_parser_t::parse() optional<date_specifier_t> inclusion_specifier; date_interval_t period; - date_t today = CURRENT_DATE(); - bool end_inclusive = false; + date_t today = CURRENT_DATE(); + bool end_inclusive = false; for (lexer_t::token_t tok = lexer.next_token(); tok.kind != lexer_t::token_t::END_REACHED; @@ -697,77 +697,77 @@ date_interval_t date_parser_t::parse() case lexer_t::token_t::TOK_DATE: if (! inclusion_specifier) - inclusion_specifier = date_specifier_t(); + inclusion_specifier = date_specifier_t(); determine_when(tok, *inclusion_specifier); break; case lexer_t::token_t::TOK_INT: if (! inclusion_specifier) - inclusion_specifier = date_specifier_t(); + inclusion_specifier = date_specifier_t(); determine_when(tok, *inclusion_specifier); break; case lexer_t::token_t::TOK_A_YEAR: if (! inclusion_specifier) - inclusion_specifier = date_specifier_t(); + inclusion_specifier = date_specifier_t(); determine_when(tok, *inclusion_specifier); break; case lexer_t::token_t::TOK_A_MONTH: if (! inclusion_specifier) - inclusion_specifier = date_specifier_t(); + inclusion_specifier = date_specifier_t(); determine_when(tok, *inclusion_specifier); break; case lexer_t::token_t::TOK_A_WDAY: if (! inclusion_specifier) - inclusion_specifier = date_specifier_t(); + inclusion_specifier = date_specifier_t(); determine_when(tok, *inclusion_specifier); break; case lexer_t::token_t::TOK_DASH: if (inclusion_specifier) { - since_specifier = inclusion_specifier; - until_specifier = date_specifier_t(); - inclusion_specifier = none; + since_specifier = inclusion_specifier; + until_specifier = date_specifier_t(); + inclusion_specifier = none; - tok = lexer.next_token(); - determine_when(tok, *until_specifier); + tok = lexer.next_token(); + determine_when(tok, *until_specifier); - // The dash operator is special: it has an _inclusive_ end. - end_inclusive = true; + // The dash operator is special: it has an _inclusive_ end. + end_inclusive = true; } else { - tok.unexpected(); + tok.unexpected(); } break; case lexer_t::token_t::TOK_SINCE: if (since_specifier) { - tok.unexpected(); + tok.unexpected(); } else { - since_specifier = date_specifier_t(); - tok = lexer.next_token(); - determine_when(tok, *since_specifier); + since_specifier = date_specifier_t(); + tok = lexer.next_token(); + determine_when(tok, *since_specifier); } break; case lexer_t::token_t::TOK_UNTIL: if (until_specifier) { - tok.unexpected(); + tok.unexpected(); } else { - until_specifier = date_specifier_t(); - tok = lexer.next_token(); - determine_when(tok, *until_specifier); + until_specifier = date_specifier_t(); + tok = lexer.next_token(); + determine_when(tok, *until_specifier); } break; case lexer_t::token_t::TOK_IN: if (inclusion_specifier) { - tok.unexpected(); + tok.unexpected(); } else { - inclusion_specifier = date_specifier_t(); - tok = lexer.next_token(); - determine_when(tok, *inclusion_specifier); + inclusion_specifier = date_specifier_t(); + tok = lexer.next_token(); + determine_when(tok, *inclusion_specifier); } break; @@ -776,90 +776,90 @@ date_interval_t date_parser_t::parse() case lexer_t::token_t::TOK_LAST: { int8_t adjust = 0; if (tok.kind == lexer_t::token_t::TOK_NEXT) - adjust = 1; + adjust = 1; else if (tok.kind == lexer_t::token_t::TOK_LAST) - adjust = -1; + adjust = -1; tok = lexer.next_token(); switch (tok.kind) { case lexer_t::token_t::TOK_INT: - // jww (2009-11-18): Allow things like "last 5 weeks" - assert(! "Need to allow for expressions like \"last 5 weeks\""); - tok.unexpected(); - break; + // jww (2009-11-18): Allow things like "last 5 weeks" + assert(! "Need to allow for expressions like \"last 5 weeks\""); + tok.unexpected(); + break; case lexer_t::token_t::TOK_A_MONTH: { - inclusion_specifier = date_specifier_t(); - determine_when(tok, *inclusion_specifier); - - date_t temp(today.year(), *inclusion_specifier->month, 1); - temp += gregorian::years(adjust); - inclusion_specifier = - date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year()), - temp.month()); - break; + inclusion_specifier = date_specifier_t(); + determine_when(tok, *inclusion_specifier); + + date_t temp(today.year(), *inclusion_specifier->month, 1); + temp += gregorian::years(adjust); + inclusion_specifier = + date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year()), + temp.month()); + break; } case lexer_t::token_t::TOK_A_WDAY: { - inclusion_specifier = date_specifier_t(); - determine_when(tok, *inclusion_specifier); - - date_t temp = - date_duration_t::find_nearest(today, date_duration_t::WEEKS); - while (temp.day_of_week() != inclusion_specifier->wday) - temp += gregorian::days(1); - temp += gregorian::days(7 * adjust); - inclusion_specifier = date_specifier_t(temp); - break; + inclusion_specifier = date_specifier_t(); + determine_when(tok, *inclusion_specifier); + + date_t temp = + date_duration_t::find_nearest(today, date_duration_t::WEEKS); + while (temp.day_of_week() != inclusion_specifier->wday) + temp += gregorian::days(1); + temp += gregorian::days(7 * adjust); + inclusion_specifier = date_specifier_t(temp); + break; } case lexer_t::token_t::TOK_YEAR: { - date_t temp(today); - temp += gregorian::years(adjust); - inclusion_specifier = - date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year())); - break; + date_t temp(today); + temp += gregorian::years(adjust); + inclusion_specifier = + date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year())); + break; } case lexer_t::token_t::TOK_QUARTER: { - date_t temp = - date_duration_t::find_nearest(today, date_duration_t::QUARTERS); - temp += gregorian::months(3 * adjust); - inclusion_specifier = - date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year()), - temp.month()); + date_t temp = + date_duration_t::find_nearest(today, date_duration_t::QUARTERS); + temp += gregorian::months(3 * adjust); + inclusion_specifier = + date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year()), + temp.month()); #if 0 - period.duration = date_duration_t(date_duration_t::QUARTERS, 1); + period.duration = date_duration_t(date_duration_t::QUARTERS, 1); #endif - break; + break; } case lexer_t::token_t::TOK_WEEK: { - date_t temp = - date_duration_t::find_nearest(today, date_duration_t::WEEKS); - temp += gregorian::days(7 * adjust); - inclusion_specifier = date_specifier_t(today); + date_t temp = + date_duration_t::find_nearest(today, date_duration_t::WEEKS); + temp += gregorian::days(7 * adjust); + inclusion_specifier = date_specifier_t(today); #if 0 - period.duration = date_duration_t(date_duration_t::WEEKS, 1); + period.duration = date_duration_t(date_duration_t::WEEKS, 1); #endif - break; + break; } case lexer_t::token_t::TOK_DAY: { - date_t temp(today); - temp += gregorian::days(adjust); - inclusion_specifier = date_specifier_t(temp); - break; + date_t temp(today); + temp += gregorian::days(adjust); + inclusion_specifier = date_specifier_t(temp); + break; } default: case lexer_t::token_t::TOK_MONTH: { - date_t temp(today); - temp += gregorian::months(adjust); - inclusion_specifier = - date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year()), - temp.month()); - break; + date_t temp(today); + temp += gregorian::months(adjust); + inclusion_specifier = + date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year()), + temp.month()); + break; } } } @@ -877,49 +877,49 @@ date_interval_t date_parser_t::parse() case lexer_t::token_t::TOK_EVERY: tok = lexer.next_token(); if (tok == lexer_t::token_t::TOK_INT) { - int quantity = boost::get<unsigned short>(*tok.value); - tok = lexer.next_token(); - switch (tok.kind) { - case lexer_t::token_t::TOK_YEARS: - period.duration = date_duration_t(date_duration_t::YEARS, quantity); - break; - case lexer_t::token_t::TOK_QUARTERS: - period.duration = date_duration_t(date_duration_t::QUARTERS, quantity); - break; - case lexer_t::token_t::TOK_MONTHS: - period.duration = date_duration_t(date_duration_t::MONTHS, quantity); - break; - case lexer_t::token_t::TOK_WEEKS: - period.duration = date_duration_t(date_duration_t::WEEKS, quantity); - break; - case lexer_t::token_t::TOK_DAYS: - period.duration = date_duration_t(date_duration_t::DAYS, quantity); - break; - default: - tok.unexpected(); - break; - } + int quantity = boost::get<unsigned short>(*tok.value); + tok = lexer.next_token(); + switch (tok.kind) { + case lexer_t::token_t::TOK_YEARS: + period.duration = date_duration_t(date_duration_t::YEARS, quantity); + break; + case lexer_t::token_t::TOK_QUARTERS: + period.duration = date_duration_t(date_duration_t::QUARTERS, quantity); + break; + case lexer_t::token_t::TOK_MONTHS: + period.duration = date_duration_t(date_duration_t::MONTHS, quantity); + break; + case lexer_t::token_t::TOK_WEEKS: + period.duration = date_duration_t(date_duration_t::WEEKS, quantity); + break; + case lexer_t::token_t::TOK_DAYS: + period.duration = date_duration_t(date_duration_t::DAYS, quantity); + break; + default: + tok.unexpected(); + break; + } } else { - switch (tok.kind) { - case lexer_t::token_t::TOK_YEAR: - period.duration = date_duration_t(date_duration_t::YEARS, 1); - break; - case lexer_t::token_t::TOK_QUARTER: - period.duration = date_duration_t(date_duration_t::QUARTERS, 1); - break; - case lexer_t::token_t::TOK_MONTH: - period.duration = date_duration_t(date_duration_t::MONTHS, 1); - break; - case lexer_t::token_t::TOK_WEEK: - period.duration = date_duration_t(date_duration_t::WEEKS, 1); - break; - case lexer_t::token_t::TOK_DAY: - period.duration = date_duration_t(date_duration_t::DAYS, 1); - break; - default: - tok.unexpected(); - break; - } + switch (tok.kind) { + case lexer_t::token_t::TOK_YEAR: + period.duration = date_duration_t(date_duration_t::YEARS, 1); + break; + case lexer_t::token_t::TOK_QUARTER: + period.duration = date_duration_t(date_duration_t::QUARTERS, 1); + break; + case lexer_t::token_t::TOK_MONTH: + period.duration = date_duration_t(date_duration_t::MONTHS, 1); + break; + case lexer_t::token_t::TOK_WEEK: + period.duration = date_duration_t(date_duration_t::WEEKS, 1); + break; + case lexer_t::token_t::TOK_DAY: + period.duration = date_duration_t(date_duration_t::DAYS, 1); + break; + default: + tok.unexpected(); + break; + } } break; @@ -983,13 +983,13 @@ void date_interval_t::resolve_end() if (start && ! end_of_duration) { end_of_duration = duration->add(*start); DEBUG("times.interval", - "stabilize: end_of_duration = " << *end_of_duration); + "stabilize: end_of_duration = " << *end_of_duration); } if (finish && *end_of_duration > *finish) { end_of_duration = finish; DEBUG("times.interval", - "stabilize: end_of_duration reset to end: " << *end_of_duration); + "stabilize: end_of_duration reset to end: " << *end_of_duration); } if (start && ! next) { @@ -1009,9 +1009,9 @@ date_t date_duration_t::find_nearest(const date_t& date, skip_quantum_t skip) case date_duration_t::QUARTERS: result = date_t(date.year(), date.month(), 1); while (result.month() != gregorian::Jan && - result.month() != gregorian::Apr && - result.month() != gregorian::Jul && - result.month() != gregorian::Oct) + result.month() != gregorian::Apr && + result.month() != gregorian::Jul && + result.month() != gregorian::Oct) result -= gregorian::months(1); break; case date_duration_t::MONTHS: @@ -1043,7 +1043,7 @@ void date_interval_t::stabilize(const optional<date_t>& date) DEBUG("times.interval", "stabilize: date passed, but not aligned"); if (duration) { DEBUG("times.interval", - "stabilize: aligning with a duration: " << *duration); + "stabilize: aligning with a duration: " << *duration); // The interval object has not been seeded with a start date yet, so // find the nearest period before on on date which fits, if possible. @@ -1057,71 +1057,71 @@ void date_interval_t::stabilize(const optional<date_t>& date) #if defined(DEBUG_ON) if (initial_start) - DEBUG("times.interval", - "stabilize: initial_start = " << *initial_start); + DEBUG("times.interval", + "stabilize: initial_start = " << *initial_start); if (initial_finish) - DEBUG("times.interval", - "stabilize: initial_finish = " << *initial_finish); + DEBUG("times.interval", + "stabilize: initial_finish = " << *initial_finish); #endif date_t when = start ? *start : *date; if (duration->quantum == date_duration_t::MONTHS || - duration->quantum == date_duration_t::QUARTERS || - duration->quantum == date_duration_t::YEARS) { - DEBUG("times.interval", - "stabilize: monthly, quarterly or yearly duration"); - start = date_duration_t::find_nearest(when, duration->quantum); + duration->quantum == date_duration_t::QUARTERS || + duration->quantum == date_duration_t::YEARS) { + DEBUG("times.interval", + "stabilize: monthly, quarterly or yearly duration"); + start = date_duration_t::find_nearest(when, duration->quantum); } else { - DEBUG("times.interval", "stabilize: daily or weekly duration"); - start = date_duration_t::find_nearest(when - gregorian::days(400), - duration->quantum); + DEBUG("times.interval", "stabilize: daily or weekly duration"); + start = date_duration_t::find_nearest(when - gregorian::days(400), + duration->quantum); } DEBUG("times.interval", - "stabilize: beginning start date = " << *start); + "stabilize: beginning start date = " << *start); while (*start < *date) { - date_interval_t next_interval(*this); - ++next_interval; - - if (next_interval.start && *next_interval.start < *date) { - *this = next_interval; - } else { - end_of_duration = none; - next = none; - break; - } + date_interval_t next_interval(*this); + ++next_interval; + + if (next_interval.start && *next_interval.start < *date) { + *this = next_interval; + } else { + end_of_duration = none; + next = none; + break; + } } DEBUG("times.interval", "stabilize: proposed start date = " << *start); if (initial_start && (! start || *start < *initial_start)) { - // Using the discovered start, find the end of the period - resolve_end(); + // Using the discovered start, find the end of the period + resolve_end(); - start = initial_start; - DEBUG("times.interval", "stabilize: start reset to initial start"); + start = initial_start; + DEBUG("times.interval", "stabilize: start reset to initial start"); } if (initial_finish && (! finish || *finish > *initial_finish)) { - finish = initial_finish; - DEBUG("times.interval", "stabilize: finish reset to initial finish"); + finish = initial_finish; + DEBUG("times.interval", "stabilize: finish reset to initial finish"); } #if defined(DEBUG_ON) if (start) - DEBUG("times.interval", "stabilize: final start = " << *start); + DEBUG("times.interval", "stabilize: final start = " << *start); if (finish) - DEBUG("times.interval", "stabilize: final finish = " << *finish); + DEBUG("times.interval", "stabilize: final finish = " << *finish); #endif } else if (range) { if (date) { - start = range->begin(date->year()); - finish = range->end(date->year()); + start = range->begin(date->year()); + finish = range->end(date->year()); } else { - start = range->begin(); - finish = range->end(); + start = range->begin(); + finish = range->end(); } } aligned = true; @@ -1134,7 +1134,7 @@ void date_interval_t::stabilize(const optional<date_t>& date) if (! start && ! finish) throw_(date_error, - _("Invalid date interval: neither start, nor finish, nor duration")); + _("Invalid date interval: neither start, nor finish, nor duration")); } else { resolve_end(); } @@ -1146,7 +1146,7 @@ bool date_interval_t::find_period(const date_t& date) if (finish && date > *finish) { DEBUG("times.interval", - "false: date [" << date << "] > finish [" << *finish << "]"); + "false: date [" << date << "] > finish [" << *finish << "]"); return false; } @@ -1155,15 +1155,15 @@ bool date_interval_t::find_period(const date_t& date) } else if (date < *start) { DEBUG("times.interval", - "false: date [" << date << "] < start [" << *start << "]"); + "false: date [" << date << "] < start [" << *start << "]"); return false; } if (end_of_duration) { if (date < *end_of_duration) { DEBUG("times.interval", - "true: date [" << date << "] < end_of_duration [" - << *end_of_duration << "]"); + "true: date [" << date << "] < end_of_duration [" + << *end_of_duration << "]"); return true; } } else { @@ -1185,17 +1185,17 @@ bool date_interval_t::find_period(const date_t& date) while (date >= scan && (! finish || scan < *finish)) { if (date < end_of_scan) { - start = scan; + start = scan; end_of_duration = end_of_scan; - next = none; + next = none; - DEBUG("times.interval", "true: start = " << *start); + DEBUG("times.interval", "true: start = " << *start); DEBUG("times.interval", "true: end_of_duration = " << *end_of_duration); return true; } - scan = duration->add(scan); + scan = duration->add(scan); end_of_scan = duration->add(scan); } @@ -1211,7 +1211,7 @@ date_interval_t& date_interval_t::operator++() if (! duration) throw_(date_error, - _("Cannot increment a date interval without a duration")); + _("Cannot increment a date interval without a duration")); assert(next); @@ -1319,16 +1319,16 @@ date_parser_t::lexer_t::token_t date_parser_t::lexer_t::next_token() date_traits_t traits; date_t when = parse_date_mask(possible_date.c_str(), none, &traits); if (! when.is_not_a_date()) { - begin = i; - return token_t(token_t::TOK_DATE, - token_t::content_t(date_specifier_t(when, traits))); + begin = i; + return token_t(token_t::TOK_DATE, + token_t::content_t(date_specifier_t(when, traits))); } } catch (date_error&) { if (contains(possible_date, "/") || - contains(possible_date, "-") || - contains(possible_date, ".")) - throw; + contains(possible_date, "-") || + contains(possible_date, ".")) + throw; } } @@ -1337,85 +1337,85 @@ date_parser_t::lexer_t::token_t date_parser_t::lexer_t::next_token() string term; bool alnum = std::isalnum(*begin); for (; (begin != end && ! std::isspace(*begin) && - ((alnum && static_cast<bool>(std::isalnum(*begin))) || - (! alnum && ! static_cast<bool>(std::isalnum(*begin))))); begin++) + ((alnum && static_cast<bool>(std::isalnum(*begin))) || + (! alnum && ! static_cast<bool>(std::isalnum(*begin))))); begin++) term.push_back(*begin); if (! term.empty()) { if (std::isdigit(term[0])) { if (term.length() == 4) - return token_t(token_t::TOK_A_YEAR, - token_t::content_t - (lexical_cast<date_specifier_t::year_type>(term))); + return token_t(token_t::TOK_A_YEAR, + token_t::content_t + (lexical_cast<date_specifier_t::year_type>(term))); else - return token_t(token_t::TOK_INT, - token_t::content_t(lexical_cast<unsigned short>(term))); + return token_t(token_t::TOK_INT, + token_t::content_t(lexical_cast<unsigned short>(term))); } else if (std::isalpha(term[0])) { to_lower(term); if (optional<date_time::months_of_year> month = - string_to_month_of_year(term)) { - return token_t(token_t::TOK_A_MONTH, token_t::content_t(*month)); + string_to_month_of_year(term)) { + return token_t(token_t::TOK_A_MONTH, token_t::content_t(*month)); } else if (optional<date_time::weekdays> wday = - string_to_day_of_week(term)) { - return token_t(token_t::TOK_A_WDAY, token_t::content_t(*wday)); + string_to_day_of_week(term)) { + return token_t(token_t::TOK_A_WDAY, token_t::content_t(*wday)); } else if (term == _("from") || term == _("since")) - return token_t(token_t::TOK_SINCE); + return token_t(token_t::TOK_SINCE); else if (term == _("to") || term == _("until")) - return token_t(token_t::TOK_UNTIL); + return token_t(token_t::TOK_UNTIL); else if (term == _("in")) - return token_t(token_t::TOK_IN); + return token_t(token_t::TOK_IN); else if (term == _("this")) - return token_t(token_t::TOK_THIS); + return token_t(token_t::TOK_THIS); else if (term == _("next")) - return token_t(token_t::TOK_NEXT); + return token_t(token_t::TOK_NEXT); else if (term == _("last")) - return token_t(token_t::TOK_LAST); + return token_t(token_t::TOK_LAST); else if (term == _("every")) - return token_t(token_t::TOK_EVERY); + return token_t(token_t::TOK_EVERY); else if (term == _("today")) - return token_t(token_t::TOK_TODAY); + return token_t(token_t::TOK_TODAY); else if (term == _("tomorrow")) - return token_t(token_t::TOK_TOMORROW); + return token_t(token_t::TOK_TOMORROW); else if (term == _("yesterday")) - return token_t(token_t::TOK_YESTERDAY); + return token_t(token_t::TOK_YESTERDAY); else if (term == _("year")) - return token_t(token_t::TOK_YEAR); + return token_t(token_t::TOK_YEAR); else if (term == _("quarter")) - return token_t(token_t::TOK_QUARTER); + return token_t(token_t::TOK_QUARTER); else if (term == _("month")) - return token_t(token_t::TOK_MONTH); + return token_t(token_t::TOK_MONTH); else if (term == _("week")) - return token_t(token_t::TOK_WEEK); + return token_t(token_t::TOK_WEEK); else if (term == _("day")) - return token_t(token_t::TOK_DAY); + return token_t(token_t::TOK_DAY); else if (term == _("yearly")) - return token_t(token_t::TOK_YEARLY); + return token_t(token_t::TOK_YEARLY); else if (term == _("quarterly")) - return token_t(token_t::TOK_QUARTERLY); + return token_t(token_t::TOK_QUARTERLY); else if (term == _("bimonthly")) - return token_t(token_t::TOK_BIMONTHLY); + return token_t(token_t::TOK_BIMONTHLY); else if (term == _("monthly")) - return token_t(token_t::TOK_MONTHLY); + return token_t(token_t::TOK_MONTHLY); else if (term == _("biweekly")) - return token_t(token_t::TOK_BIWEEKLY); + return token_t(token_t::TOK_BIWEEKLY); else if (term == _("weekly")) - return token_t(token_t::TOK_WEEKLY); + return token_t(token_t::TOK_WEEKLY); else if (term == _("daily")) - return token_t(token_t::TOK_DAILY); + return token_t(token_t::TOK_DAILY); else if (term == _("years")) - return token_t(token_t::TOK_YEARS); + return token_t(token_t::TOK_YEARS); else if (term == _("quarters")) - return token_t(token_t::TOK_QUARTERS); + return token_t(token_t::TOK_QUARTERS); else if (term == _("months")) - return token_t(token_t::TOK_MONTHS); + return token_t(token_t::TOK_MONTHS); else if (term == _("weeks")) - return token_t(token_t::TOK_WEEKS); + return token_t(token_t::TOK_WEEKS); else if (term == _("days")) - return token_t(token_t::TOK_DAYS); + return token_t(token_t::TOK_DAYS); } else { token_t::expected('\0', term[0]); @@ -1462,12 +1462,12 @@ namespace { typedef std::map<std::string, date_io_t *> date_io_map; datetime_io_map temp_datetime_io; - date_io_map temp_date_io; + date_io_map temp_date_io; } -std::string format_datetime(const datetime_t& when, - const format_type_t format_type, - const optional<const char *>& format) +std::string format_datetime(const datetime_t& when, + const format_type_t format_type, + const optional<const char *>& format) { if (format_type == FMT_WRITTEN) { return written_datetime_io->format(when); @@ -1491,9 +1491,9 @@ std::string format_datetime(const datetime_t& when, } } -std::string format_date(const date_t& when, - const format_type_t format_type, - const optional<const char *>& format) +std::string format_date(const date_t& when, + const format_type_t format_type, + const optional<const char *>& format) { if (format_type == FMT_WRITTEN) { return written_date_io->format(when); diff --git a/src/times.h b/src/times.h index 51cc8491..02b39ef7 100644 --- a/src/times.h +++ b/src/times.h @@ -51,8 +51,8 @@ namespace ledger { DECLARE_EXCEPTION(datetime_error, std::runtime_error); DECLARE_EXCEPTION(date_error, std::runtime_error); -typedef boost::posix_time::ptime datetime_t; -typedef datetime_t::time_duration_type time_duration_t; +typedef boost::posix_time::ptime datetime_t; +typedef datetime_t::time_duration_type time_duration_t; inline bool is_valid(const datetime_t& moment) { return ! moment.is_not_a_date_time(); @@ -89,14 +89,14 @@ typedef optional<date_t::year_type> optional_year; datetime_t parse_datetime(const char * str, optional_year current_year = none); inline datetime_t parse_datetime(const std::string& str, - optional_year current_year = none) { + optional_year current_year = none) { return parse_datetime(str.c_str(), current_year); } date_t parse_date(const char * str, optional_year current_year = none); inline date_t parse_date(const std::string& str, - optional_year current_year = none) { + optional_year current_year = none) { return parse_date(str.c_str(), current_year); } @@ -105,18 +105,18 @@ enum format_type_t { }; std::string format_datetime(const datetime_t& when, - const format_type_t format_type = FMT_PRINTED, - const optional<const char *>& format = none); + const format_type_t format_type = FMT_PRINTED, + const optional<const char *>& format = none); void set_datetime_format(const char * format); std::string format_date(const date_t& when, - const format_type_t format_type = FMT_PRINTED, - const optional<const char *>& format = none); + const format_type_t format_type = FMT_PRINTED, + const optional<const char *>& format = none); void set_date_format(const char * format); void set_input_date_format(const char * format); inline void to_xml(std::ostream& out, const datetime_t& when, - bool wrap = true) + bool wrap = true) { if (wrap) { push_xml x(out, "datetime"); @@ -127,7 +127,7 @@ inline void to_xml(std::ostream& out, const datetime_t& when, } inline void to_xml(std::ostream& out, const date_t& when, - bool wrap = true) + bool wrap = true) { if (wrap) { push_xml x(out, "date"); @@ -144,8 +144,8 @@ struct date_traits_t bool has_day; date_traits_t(bool _has_year = false, - bool _has_month = false, - bool _has_day = false) + bool _has_month = false, + bool _has_day = false) : has_year(_has_year), has_month(_has_month), has_day(_has_day) { TRACE_CTOR(date_traits_t, "bool, bool, bool"); } @@ -160,16 +160,16 @@ struct date_traits_t } date_traits_t& operator=(const date_traits_t& traits) { - has_year = traits.has_year; + has_year = traits.has_year; has_month = traits.has_month; - has_day = traits.has_day; + has_day = traits.has_day; return *this; } bool operator==(const date_traits_t& traits) const { - return (has_year == traits.has_year && - has_month == traits.has_month && - has_day == traits.has_day); + return (has_year == traits.has_year && + has_month == traits.has_month && + has_day == traits.has_day); } #if defined(HAVE_BOOST_SERIALIZATION) @@ -249,11 +249,11 @@ struct date_duration_t out << length << ' '; switch (quantum) { - case DAYS: out << "day"; break; - case WEEKS: out << "week"; break; + case DAYS: out << "day"; break; + case WEEKS: out << "week"; break; case MONTHS: out << "month"; break; case QUARTERS: out << "quarter"; break; - case YEARS: out << "year"; break; + case YEARS: out << "year"; break; default: assert(false); break; @@ -287,31 +287,31 @@ class date_specifier_t public: #if 0 - typedef date_t::year_type year_type; + typedef date_t::year_type year_type; #else - typedef unsigned short year_type; + typedef unsigned short year_type; #endif - typedef date_t::month_type month_type; - typedef date_t::day_type day_type; + typedef date_t::month_type month_type; + typedef date_t::day_type day_type; typedef date_t::day_of_week_type day_of_week_type; protected: - optional<year_type> year; - optional<month_type> month; - optional<day_type> day; + optional<year_type> year; + optional<month_type> month; + optional<day_type> day; optional<day_of_week_type> wday; public: date_specifier_t(const optional<year_type>& _year = none, - const optional<month_type>& _month = none, - const optional<day_type>& _day = none, - const optional<day_of_week_type>& _wday = none) + const optional<month_type>& _month = none, + const optional<day_type>& _day = none, + const optional<day_of_week_type>& _wday = none) : year(_year), month(_month), day(_day), wday(_wday) { TRACE_CTOR(date_specifier_t, - "year_type, month_type, day_type, day_of_week_type"); + "year_type, month_type, day_type, day_of_week_type"); } date_specifier_t(const date_t& date, - const optional<date_traits_t>& traits = none) { + const optional<date_traits_t>& traits = none) { TRACE_CTOR(date_specifier_t, "date_t, date_traits_t"); if (! traits || traits->has_year) year = date.year(); @@ -333,7 +333,7 @@ public: date_t end(const optional_year& current_year = none) const; bool is_within(const date_t& date, - const optional_year& current_year = none) const { + const optional_year& current_year = none) const { return date >= begin(current_year) && date < end(current_year); } @@ -390,7 +390,7 @@ class date_range_t public: date_range_t(const optional<date_specifier_t>& _range_begin = none, - const optional<date_specifier_t>& _range_end = none) + const optional<date_specifier_t>& _range_end = none) : range_begin(_range_begin), range_end(_range_end), end_inclusive(false) { TRACE_CTOR(date_range_t, "date_specifier_t, date_specifier_t"); @@ -413,16 +413,16 @@ public: optional<date_t> end(const optional_year& current_year = none) const { if (range_end) { if (end_inclusive) - return range_end->end(current_year); + return range_end->end(current_year); else - return range_end->begin(current_year); + return range_end->begin(current_year); } else { return none; } } bool is_within(const date_t& date, - const optional_year& current_year = none) const { + const optional_year& current_year = none) const { optional<date_t> b = begin(current_year); optional<date_t> e = end(current_year); bool after_begin = b ? date >= *b : true; @@ -527,19 +527,19 @@ private: class date_interval_t : public equality_comparable<date_interval_t> { public: - static date_t add_duration(const date_t& date, - const date_duration_t& duration); - static date_t subtract_duration(const date_t& date, - const date_duration_t& duration); + static date_t add_duration(const date_t& date, + const date_duration_t& duration); + static date_t subtract_duration(const date_t& date, + const date_duration_t& duration); optional<date_specifier_or_range_t> range; - optional<date_t> start; // the real start, after adjustment - optional<date_t> finish; // the real end, likewise - bool aligned; - optional<date_t> next; + optional<date_t> start; // the real start, after adjustment + optional<date_t> finish; // the real end, likewise + bool aligned; + optional<date_t> next; optional<date_duration_t> duration; - optional<date_t> end_of_duration; + optional<date_t> end_of_duration; explicit date_interval_t() : aligned(false) { TRACE_CTOR(date_interval_t, ""); @@ -564,7 +564,7 @@ public: bool operator==(const date_interval_t& other) const { return (start == other.start && - (! start || *start == *other.start)); + (! start || *start == *other.start)); } operator bool() const { @@ -580,8 +580,8 @@ public: void parse(const string& str); - void resolve_end(); - void stabilize(const optional<date_t>& date = none); + void resolve_end(); + void stabilize(const optional<date_t>& date = none); bool is_valid() const { return start; diff --git a/src/token.cc b/src/token.cc index 905e13fe..9dfff065 100644 --- a/src/token.cc +++ b/src/token.cc @@ -50,74 +50,74 @@ int expr_t::token_t::parse_reserved_word(std::istream& in) switch (buf[0]) { case 'a': if (std::strcmp(buf, "and") == 0) { - symbol[0] = '&'; - symbol[1] = '\0'; - kind = KW_AND; - return 1; + symbol[0] = '&'; + symbol[1] = '\0'; + kind = KW_AND; + return 1; } break; case 'd': if (std::strcmp(buf, "div") == 0) { - symbol[0] = '/'; - symbol[1] = '/'; - symbol[2] = '\0'; - kind = KW_DIV; - return 1; + symbol[0] = '/'; + symbol[1] = '/'; + symbol[2] = '\0'; + kind = KW_DIV; + return 1; } break; case 'e': if (std::strcmp(buf, "else") == 0) { - symbol[0] = 'L'; - symbol[1] = 'S'; - symbol[2] = '\0'; - kind = KW_ELSE; - return 1; + symbol[0] = 'L'; + symbol[1] = 'S'; + symbol[2] = '\0'; + kind = KW_ELSE; + return 1; } break; case 'f': if (std::strcmp(buf, "false") == 0) { - kind = VALUE; - value = false; - return 1; + kind = VALUE; + value = false; + return 1; } break; case 'i': if (std::strcmp(buf, "if") == 0) { - symbol[0] = 'i'; - symbol[1] = 'f'; - symbol[2] = '\0'; - kind = KW_IF; - return 1; + symbol[0] = 'i'; + symbol[1] = 'f'; + symbol[2] = '\0'; + kind = KW_IF; + return 1; } break; case 'o': if (std::strcmp(buf, "or") == 0) { - symbol[0] = '|'; - symbol[1] = '\0'; - kind = KW_OR; - return 1; + symbol[0] = '|'; + symbol[1] = '\0'; + kind = KW_OR; + return 1; } break; case 'n': if (std::strcmp(buf, "not") == 0) { - symbol[0] = '!'; - symbol[1] = '\0'; - kind = EXCLAM; - return 1; + symbol[0] = '!'; + symbol[1] = '\0'; + kind = EXCLAM; + return 1; } break; case 't': if (std::strcmp(buf, "true") == 0) { - kind = VALUE; - value = true; - return 1; + kind = VALUE; + value = true; + return 1; } break; } @@ -129,7 +129,7 @@ int expr_t::token_t::parse_reserved_word(std::istream& in) void expr_t::token_t::parse_ident(std::istream& in) { - kind = IDENT; + kind = IDENT; length = 0; char c, buf[256]; @@ -139,7 +139,7 @@ void expr_t::token_t::parse_ident(std::istream& in) } void expr_t::token_t::next(std::istream& in, const parse_flags_t& pflags, - const char expecting) + const char expecting) { if (in.eof()) { kind = TOK_EOF; @@ -210,7 +210,7 @@ void expr_t::token_t::next(std::istream& in, const parse_flags_t& pflags, optional<date_t> begin = timespan.begin(); if (! begin) throw_(parse_error, - _("Date specifier does not refer to a starting date")); + _("Date specifier does not refer to a starting date")); kind = VALUE; value = *begin; break; @@ -302,12 +302,12 @@ void expr_t::token_t::next(std::istream& in, const parse_flags_t& pflags, in.get(c); if (pflags.has_flags(PARSE_OP_CONTEXT)) { // operator context kind = SLASH; - } else { // terminal context + } else { // terminal context // Read in the regexp char buf[256]; READ_INTO_(in, buf, 255, c, length, c != '/'); if (c != '/') - expected('/', c); + expected('/', c); in.get(c); length++; @@ -395,7 +395,7 @@ void expr_t::token_t::next(std::istream& in, const parse_flags_t& pflags, in.clear(); in.seekg(pos, std::ios::beg); if (in.fail()) - throw_(parse_error, _("Failed to reset input stream")); + throw_(parse_error, _("Failed to reset input stream")); } // When in relaxed parsing mode, we want to migrate commodity flags @@ -411,30 +411,30 @@ void expr_t::token_t::next(std::istream& in, const parse_flags_t& pflags, try { amount_t temp; if (! temp.parse(in, parse_flags.plus_flags(PARSE_SOFT_FAIL))) { - // If the amount had no commodity, it must be an unambiguous - // variable reference - - in.clear(); - in.seekg(pos, std::ios::beg); - if (in.fail()) - throw_(parse_error, _("Failed to reset input stream")); - - c = static_cast<char>(in.peek()); - if (std::isdigit(c) || c == '.') - expected('\0', c); - - parse_ident(in); - - if (value.as_string().length() == 0) { - kind = ERROR; - symbol[0] = c; - symbol[1] = '\0'; - unexpected(expecting); - } + // If the amount had no commodity, it must be an unambiguous + // variable reference + + in.clear(); + in.seekg(pos, std::ios::beg); + if (in.fail()) + throw_(parse_error, _("Failed to reset input stream")); + + c = static_cast<char>(in.peek()); + if (std::isdigit(c) || c == '.') + expected('\0', c); + + parse_ident(in); + + if (value.as_string().length() == 0) { + kind = ERROR; + symbol[0] = c; + symbol[1] = '\0'; + unexpected(expecting); + } } else { - kind = VALUE; - value = temp; - length = static_cast<std::size_t>(in.tellg() - pos); + kind = VALUE; + value = temp; + length = static_cast<std::size_t>(in.tellg() - pos); } } catch (const std::exception& err) { @@ -476,16 +476,16 @@ void expr_t::token_t::unexpected(const char wanted) switch (prev_kind) { case TOK_EOF: throw_(parse_error, - _("Unexpected end of expression (wanted '%1')") << wanted); + _("Unexpected end of expression (wanted '%1')") << wanted); case IDENT: throw_(parse_error, - _("Unexpected symbol '%1' (wanted '%2')") << value << wanted); + _("Unexpected symbol '%1' (wanted '%2')") << value << wanted); case VALUE: throw_(parse_error, - _("Unexpected value '%1' (wanted '%2')") << value << wanted); + _("Unexpected value '%1' (wanted '%2')") << value << wanted); default: throw_(parse_error, _("Unexpected expression token '%1' (wanted '%2')") - << symbol << wanted); + << symbol << wanted); } } } diff --git a/src/token.h b/src/token.h index 582373cb..aae73837 100644 --- a/src/token.h +++ b/src/token.h @@ -49,52 +49,52 @@ namespace ledger { struct expr_t::token_t : public noncopyable { enum kind_t { - ERROR, // an error occurred while tokenizing - VALUE, // any kind of literal value - IDENT, // [A-Za-z_][-A-Za-z0-9_:]* - MASK, // /regexp/ - - LPAREN, // ( - RPAREN, // ) - - EQUAL, // == - NEQUAL, // != - LESS, // < - LESSEQ, // <= - GREATER, // > - GREATEREQ, // >= - - DEFINE, // := - ASSIGN, // = - MATCH, // =~ - NMATCH, // !~ - MINUS, // - - PLUS, // + - STAR, // * - SLASH, // / - KW_DIV, // div - - EXCLAM, // !, not - KW_AND, // &, &&, and - KW_OR, // |, ||, or - KW_MOD, // % - - KW_IF, // if - KW_ELSE, // else - - QUERY, // ? - COLON, // : - - DOT, // . - COMMA, // , - SEMI, // ; + ERROR, // an error occurred while tokenizing + VALUE, // any kind of literal value + IDENT, // [A-Za-z_][-A-Za-z0-9_:]* + MASK, // /regexp/ + + LPAREN, // ( + RPAREN, // ) + + EQUAL, // == + NEQUAL, // != + LESS, // < + LESSEQ, // <= + GREATER, // > + GREATEREQ, // >= + + DEFINE, // := + ASSIGN, // = + MATCH, // =~ + NMATCH, // !~ + MINUS, // - + PLUS, // + + STAR, // * + SLASH, // / + KW_DIV, // div + + EXCLAM, // !, not + KW_AND, // &, &&, and + KW_OR, // |, ||, or + KW_MOD, // % + + KW_IF, // if + KW_ELSE, // else + + QUERY, // ? + COLON, // : + + DOT, // . + COMMA, // , + SEMI, // ; TOK_EOF, UNKNOWN } kind; - char symbol[3]; + char symbol[3]; value_t value; std::size_t length; @@ -108,7 +108,7 @@ struct expr_t::token_t : public noncopyable token_t& operator=(const token_t& other) { if (&other == this) return *this; - assert(false); // only one token object is used at a time + assert(false); // only one token object is used at a time return *this; } @@ -125,7 +125,7 @@ struct expr_t::token_t : public noncopyable int parse_reserved_word(std::istream& in); void parse_ident(std::istream& in); void next(std::istream& in, const parse_flags_t& flags, - const char expecting = '\0'); + const char expecting = '\0'); void rewind(std::istream& in); void unexpected(const char wanted = '\0'); void expected(const char wanted, char c = '\0'); diff --git a/src/unistring.h b/src/unistring.h index d42f2b28..979ce08b 100644 --- a/src/unistring.h +++ b/src/unistring.h @@ -67,7 +67,7 @@ public: TRACE_CTOR(unistring, "std::string"); const char * p = input.c_str(); - std::size_t len = input.length(); + std::size_t len = input.length(); VERIFY(utf8::is_valid(p, p + len)); utf8::unchecked::utf8to32(p, p + len, std::back_inserter(utf32chars)); @@ -81,9 +81,9 @@ public: } std::string extract(const std::string::size_type begin = 0, - const std::string::size_type len = 0) const + const std::string::size_type len = 0) const { - std::string utf8result; + std::string utf8result; std::string::size_type this_len = length(); assert(begin <= this_len); @@ -91,10 +91,10 @@ public: if (this_len) utf8::unchecked::utf32to8 - (utf32chars.begin() + begin, - utf32chars.begin() + begin + - (len ? (len > this_len ? this_len : len) : this_len), - std::back_inserter(utf8result)); + (utf32chars.begin() + begin, + utf32chars.begin() + begin + + (len ? (len > this_len ? this_len : len) : this_len), + std::back_inserter(utf8result)); return utf8result; } @@ -103,7 +103,7 @@ public: std::size_t idx = 0; foreach (const boost::uint32_t& ch, utf32chars) { if (idx >= __pos && ch == __s) - return idx; + return idx; idx++; } return npos; @@ -118,10 +118,10 @@ public: }; inline void justify(std::ostream& out, - const std::string& str, - int width, - bool right = false, - bool redden = false) + const std::string& str, + int width, + bool right = false, + bool redden = false) { if (! right) { if (redden) out << "\033[31m"; diff --git a/src/utils.cc b/src/utils.cc index c3fecca0..dce804ff 100644 --- a/src/utils.cc +++ b/src/utils.cc @@ -45,9 +45,9 @@ namespace ledger { DECLARE_EXCEPTION(assertion_failed, std::logic_error); void debug_assert(const string& reason, - const string& func, - const string& file, - std::size_t line) + const string& func, + const string& file, + std::size_t line) { std::ostringstream buf; buf << "Assertion failed in \"" << file << "\", line " << line @@ -80,11 +80,11 @@ typedef std::map<std::string, count_size_pair> object_count_map; namespace { bool memory_tracing_active = false; - memory_map * live_memory = NULL; - memory_map * freed_memory = NULL; + memory_map * live_memory = NULL; + memory_map * freed_memory = NULL; object_count_map * live_memory_count = NULL; object_count_map * total_memory_count = NULL; - objects_map * live_objects = NULL; + objects_map * live_objects = NULL; object_count_map * live_object_count = NULL; object_count_map * total_object_count = NULL; object_count_map * total_ctor_count = NULL; @@ -94,11 +94,11 @@ void initialize_memory_tracing() { memory_tracing_active = false; - live_memory = new memory_map; - freed_memory = new memory_map; + live_memory = new memory_map; + freed_memory = new memory_map; live_memory_count = new object_count_map; total_memory_count = new object_count_map; - live_objects = new objects_map; + live_objects = new objects_map; live_object_count = new object_count_map; total_object_count = new object_count_map; total_ctor_count = new object_count_map; @@ -119,18 +119,18 @@ void shutdown_memory_tracing() report_memory(std::cerr); } - checked_delete(live_memory); live_memory = NULL; - checked_delete(freed_memory); freed_memory = NULL; - checked_delete(live_memory_count); live_memory_count = NULL; + checked_delete(live_memory); live_memory = NULL; + checked_delete(freed_memory); freed_memory = NULL; + checked_delete(live_memory_count); live_memory_count = NULL; checked_delete(total_memory_count); total_memory_count = NULL; - checked_delete(live_objects); live_objects = NULL; - checked_delete(live_object_count); live_object_count = NULL; + checked_delete(live_objects); live_objects = NULL; + checked_delete(live_object_count); live_object_count = NULL; checked_delete(total_object_count); total_object_count = NULL; - checked_delete(total_ctor_count); total_ctor_count = NULL; + checked_delete(total_ctor_count); total_ctor_count = NULL; } inline void add_to_count_map(object_count_map& the_map, - const char * name, std::size_t size) + const char * name, std::size_t size) { object_count_map::iterator k = the_map.find(name); if (k != the_map.end()) { @@ -274,9 +274,9 @@ inline void report_count_map(std::ostream& out, object_count_map& the_map) { foreach (object_count_map::value_type& pair, the_map) out << " " << std::right << std::setw(12) << pair.second.first - << " " << std::right << std::setw(7) << pair.second.second - << " " << std::left << pair.first - << std::endl; + << " " << std::right << std::setw(7) << pair.second.second + << " " << std::left << pair.first + << std::endl; } std::size_t current_objects_size() @@ -290,7 +290,7 @@ std::size_t current_objects_size() } void trace_ctor_func(void * ptr, const char * cls_name, const char * args, - std::size_t cls_size) + std::size_t cls_size) { if (! live_objects || ! memory_tracing_active) return; @@ -358,7 +358,7 @@ void report_memory(std::ostream& out, bool report_all) if (live_memory_count->size() > 0) { out << "NOTE: There may be memory held by Boost " - << "and libstdc++ after ledger::shutdown()" << std::endl; + << "and libstdc++ after ledger::shutdown()" << std::endl; out << "Live memory count:" << std::endl; report_count_map(out, *live_memory_count); } @@ -368,9 +368,9 @@ void report_memory(std::ostream& out, bool report_all) foreach (const memory_map::value_type& pair, *live_memory) out << " " << std::right << std::setw(12) << pair.first - << " " << std::right << std::setw(7) << pair.second.second - << " " << std::left << pair.second.first - << std::endl; + << " " << std::right << std::setw(7) << pair.second.second + << " " << std::left << pair.second.first + << std::endl; } if (report_all && total_memory_count->size() > 0) { @@ -388,9 +388,9 @@ void report_memory(std::ostream& out, bool report_all) foreach (const objects_map::value_type& pair, *live_objects) out << " " << std::right << std::setw(12) << pair.first - << " " << std::right << std::setw(7) << pair.second.second - << " " << std::left << pair.second.first - << std::endl; + << " " << std::right << std::setw(7) << pair.second.second + << " " << std::left << pair.second.first + << std::endl; } if (report_all) { @@ -470,28 +470,28 @@ strings_list split_arguments(const char * line) for (const char * p = line; *p; p++) { if (! in_quoted_string && std::isspace(*p)) { if (q != buf) { - *q = '\0'; - args.push_back(buf); - q = buf; + *q = '\0'; + args.push_back(buf); + q = buf; } } else if (in_quoted_string != '\'' && *p == '\\') { p++; if (! *p) - throw_(std::logic_error, _("Invalid use of backslash")); + throw_(std::logic_error, _("Invalid use of backslash")); *q++ = *p; } else if (in_quoted_string != '"' && *p == '\'') { if (in_quoted_string == '\'') - in_quoted_string = '\0'; + in_quoted_string = '\0'; else - in_quoted_string = '\''; + in_quoted_string = '\''; } else if (in_quoted_string != '\'' && *p == '"') { if (in_quoted_string == '"') - in_quoted_string = '\0'; + in_quoted_string = '\0'; else - in_quoted_string = '"'; + in_quoted_string = '"'; } else { *q++ = *p; @@ -500,7 +500,7 @@ strings_list split_arguments(const char * line) if (in_quoted_string) throw_(std::logic_error, - _("Unterminated string, expected '%1'") << in_quoted_string); + _("Unterminated string, expected '%1'") << in_quoted_string); if (q != buf) { *q = '\0'; @@ -521,12 +521,12 @@ strings_list split_arguments(const char * line) namespace ledger { -log_level_t _log_level = LOG_WARN; -std::ostream * _log_stream = &std::cerr; +log_level_t _log_level = LOG_WARN; +std::ostream * _log_stream = &std::cerr; std::ostringstream _log_buffer; #if defined(TRACING_ON) -uint8_t _trace_level; +uint8_t _trace_level; #endif static inline void stream_memory_size(std::ostream& out, std::size_t size) @@ -560,8 +560,8 @@ bool logger_func(log_level_t level) } *_log_stream << std::right << std::setw(5) - << (TRUE_CURRENT_TIME() - - logger_start).total_milliseconds() << "ms"; + << (TRUE_CURRENT_TIME() - + logger_start).total_milliseconds() << "ms"; #if defined(VERIFY_ON) IF_VERIFY() { @@ -593,6 +593,7 @@ bool logger_func(log_level_t level) } *_log_stream << ' ' << _log_buffer.str() << std::endl; + _log_buffer.clear(); _log_buffer.str(""); return true; @@ -632,11 +633,11 @@ namespace ledger { struct timer_t { - log_level_t level; - ptime begin; - time_duration spent; - std::string description; - bool active; + log_level_t level; + ptime begin; + time_duration spent; + std::string description; + bool active; timer_t(log_level_t _level, std::string _description) : level(_level), begin(TRUE_CURRENT_TIME()), @@ -663,6 +664,7 @@ void start_timer(const char * name, log_level_t lvl) (*i).second.begin = TRUE_CURRENT_TIME(); (*i).second.active = true; } + _log_buffer.clear(); _log_buffer.str(""); #if defined(VERIFY_ON) @@ -767,7 +769,7 @@ path expand_path(const path& pathname) return pathname; std::string path_string = pathname.string(); - const char * pfx = NULL; + const char * pfx = NULL; string::size_type pos = path_string.find_first_of('/'); if (path_string.length() == 1 || pos == 1) { @@ -777,14 +779,14 @@ path expand_path(const path& pathname) // Punt. We're trying to expand ~/, but HOME isn't set struct passwd * pw = getpwuid(getuid()); if (pw) - pfx = pw->pw_dir; + pfx = pw->pw_dir; } #endif } #ifdef HAVE_GETPWNAM else { string user(path_string, 1, pos == string::npos ? - string::npos : pos - 1); + string::npos : pos - 1); struct passwd * pw = getpwnam(user.c_str()); if (pw) pfx = pw->pw_dir; diff --git a/src/utils.h b/src/utils.h index 9135abde..40fa57cc 100644 --- a/src/utils.h +++ b/src/utils.h @@ -59,7 +59,7 @@ #define NO_ASSERTS 1 //#define NO_LOGGING 1 #else -#define TRACING_ON 1 // use --trace X to enable +#define TRACING_ON 1 // use --trace X to enable #endif /*@}*/ @@ -80,15 +80,15 @@ namespace ledger { typedef std::list<string> strings_list; - typedef posix_time::ptime ptime; + typedef posix_time::ptime ptime; typedef ptime::time_duration_type time_duration; - typedef gregorian::date date; + typedef gregorian::date date; typedef gregorian::date_duration date_duration; - typedef posix_time::seconds seconds; + typedef posix_time::seconds seconds; - typedef boost::filesystem::path path; - typedef boost::filesystem::ifstream ifstream; - typedef boost::filesystem::ofstream ofstream; + typedef boost::filesystem::path path; + typedef boost::filesystem::ifstream ifstream; + typedef boost::filesystem::ofstream ofstream; typedef boost::filesystem::filesystem_error filesystem_error; } @@ -110,12 +110,12 @@ namespace ledger { namespace ledger { void debug_assert(const string& reason, const string& func, - const string& file, std::size_t line); + const string& file, std::size_t line); } -#define assert(x) \ - ((x) ? ((void)0) : debug_assert(#x, BOOST_CURRENT_FUNCTION, \ - __FILE__, __LINE__)) +#define assert(x) \ + ((x) ? ((void)0) : debug_assert(#x, BOOST_CURRENT_FUNCTION, \ + __FILE__, __LINE__)) #else // ! ASSERTS_ON @@ -146,7 +146,7 @@ std::size_t current_memory_size(); std::size_t current_objects_size(); void trace_ctor_func(void * ptr, const char * cls_name, const char * args, - std::size_t cls_size); + std::size_t cls_size); void trace_dtor_func(void * ptr, const char * cls_name, std::size_t cls_size); #define TRACE_CTOR(cls, args) \ @@ -239,8 +239,8 @@ inline string operator+(const string& __lhs, const char* __rhs) inline string operator+(const string& __lhs, char __rhs) { - typedef string __string_type; - typedef string::size_type __size_type; + typedef string __string_type; + typedef string::size_type __size_type; __string_type __str(__lhs); __str.append(__size_type(1), __rhs); return __str; @@ -301,8 +301,8 @@ enum log_level_t { LOG_ALL }; -extern log_level_t _log_level; -extern std::ostream * _log_stream; +extern log_level_t _log_level; +extern std::ostream * _log_stream; extern std::ostringstream _log_buffer; bool logger_func(log_level_t level); @@ -539,7 +539,7 @@ extern "C" char * realpath(const char *, char resolved_path[]); #endif inline const string& either_or(const string& first, - const string& second) { + const string& second) { return first.empty() ? second : first; } @@ -587,62 +587,62 @@ inline char peek_next_nonws(std::istream& in) { return c; } -#define READ_INTO(str, targ, size, var, cond) { \ - char * _p = targ; \ - var = static_cast<char>(str.peek()); \ - while (str.good() && ! str.eof() && var != '\n' && \ - (cond) && _p - targ < size) { \ - str.get(var); \ - if (str.eof()) \ - break; \ - if (var == '\\') { \ - str.get(var); \ - if (in.eof()) \ - break; \ - switch (var) { \ - case 'b': var = '\b'; break; \ - case 'f': var = '\f'; break; \ - case 'n': var = '\n'; break; \ - case 'r': var = '\r'; break; \ - case 't': var = '\t'; break; \ - case 'v': var = '\v'; break; \ - default: break; \ - } \ - } \ - *_p++ = var; \ - var = static_cast<char>(str.peek()); \ - } \ - *_p = '\0'; \ +#define READ_INTO(str, targ, size, var, cond) { \ + char * _p = targ; \ + var = static_cast<char>(str.peek()); \ + while (str.good() && ! str.eof() && var != '\n' && \ + (cond) && _p - targ < size) { \ + str.get(var); \ + if (str.eof()) \ + break; \ + if (var == '\\') { \ + str.get(var); \ + if (in.eof()) \ + break; \ + switch (var) { \ + case 'b': var = '\b'; break; \ + case 'f': var = '\f'; break; \ + case 'n': var = '\n'; break; \ + case 'r': var = '\r'; break; \ + case 't': var = '\t'; break; \ + case 'v': var = '\v'; break; \ + default: break; \ + } \ + } \ + *_p++ = var; \ + var = static_cast<char>(str.peek()); \ + } \ + *_p = '\0'; \ } -#define READ_INTO_(str, targ, size, var, idx, cond) { \ - char * _p = targ; \ - var = static_cast<char>(str.peek()); \ - while (str.good() && ! str.eof() && var != '\n' && \ - (cond) && _p - targ < size) { \ - str.get(var); \ - if (str.eof()) \ - break; \ - idx++; \ - if (var == '\\') { \ - str.get(var); \ - if (in.eof()) \ - break; \ - switch (var) { \ - case 'b': var = '\b'; break; \ - case 'f': var = '\f'; break; \ - case 'n': var = '\n'; break; \ - case 'r': var = '\r'; break; \ - case 't': var = '\t'; break; \ - case 'v': var = '\v'; break; \ - default: break; \ - } \ - idx++; \ - } \ - *_p++ = var; \ - var = static_cast<char>(str.peek()); \ - } \ - *_p = '\0'; \ +#define READ_INTO_(str, targ, size, var, idx, cond) { \ + char * _p = targ; \ + var = static_cast<char>(str.peek()); \ + while (str.good() && ! str.eof() && var != '\n' && \ + (cond) && _p - targ < size) { \ + str.get(var); \ + if (str.eof()) \ + break; \ + idx++; \ + if (var == '\\') { \ + str.get(var); \ + if (in.eof()) \ + break; \ + switch (var) { \ + case 'b': var = '\b'; break; \ + case 'f': var = '\f'; break; \ + case 'n': var = '\n'; break; \ + case 'r': var = '\r'; break; \ + case 't': var = '\t'; break; \ + case 'v': var = '\v'; break; \ + default: break; \ + } \ + idx++; \ + } \ + *_p++ = var; \ + var = static_cast<char>(str.peek()); \ + } \ + *_p = '\0'; \ } inline string to_hex(uint_least32_t * message_digest, const int len = 1) @@ -654,7 +654,7 @@ inline string to_hex(uint_least32_t * message_digest, const int len = 1) buf.fill('0'); buf << std::hex << message_digest[i]; if (i + 1 >= len) - break; // only output the first LEN dwords + break; // only output the first LEN dwords } return buf.str(); } @@ -672,12 +672,12 @@ inline string sha1sum(const string& str) class push_xml { std::ostream& out; - string tag; - bool leave_open; + string tag; + bool leave_open; public: push_xml(std::ostream& _out, const string& _tag, bool has_attrs = false, - bool _leave_open = false) + bool _leave_open = false) : out(_out), tag(_tag), leave_open(_leave_open) { out << '<' << tag; if (! has_attrs) @@ -697,17 +697,17 @@ public: foreach (const char& ch, str) { switch (ch) { case '<': - buf << "<"; - break; + buf << "<"; + break; case '>': - buf << ">"; - break; + buf << ">"; + break; case '&': - buf << "&"; - break; + buf << "&"; + break; default: - buf << ch; - break; + buf << ch; + break; } } return buf.str(); diff --git a/src/value.cc b/src/value.cc index 64193db6..63e48333 100644 --- a/src/value.cc +++ b/src/value.cc @@ -35,7 +35,7 @@ #include "commodity.h" #include "annotate.h" #include "pool.h" -#include "unistring.h" // for justify() +#include "unistring.h" // for justify() #include "op.h" namespace ledger { @@ -65,11 +65,11 @@ value_t::storage_t& value_t::storage_t::operator=(const value_t::storage_t& rhs) void value_t::initialize() { - true_value = new storage_t; + true_value = new storage_t; true_value->type = BOOLEAN; true_value->data = true; - false_value = new storage_t; + false_value = new storage_t; false_value->type = BOOLEAN; false_value->data = false; } @@ -103,14 +103,14 @@ value_t::operator bool() const std::ostringstream out; out << *this; throw_(value_error, - _("Cannot determine truth of %1 (did you mean 'account =~ %2'?)") - << label() << out.str()); + _("Cannot determine truth of %1 (did you mean 'account =~ %2'?)") + << label() << out.str()); } case SEQUENCE: if (! as_sequence().empty()) { foreach (const value_t& value, as_sequence()) { - if (value) - return true; + if (value) + return true; } } return false; @@ -122,7 +122,9 @@ value_t::operator bool() const break; } + add_error_context(_("While taking boolean value of %1:") << *this); throw_(value_error, _("Cannot determine truth of %1") << label()); + return false; } @@ -279,7 +281,7 @@ void value_t::in_place_simplify() DEBUG_("as an amount it looks like: " << *this); } -#ifdef REDUCE_TO_INTEGER // this is off by default +#ifdef REDUCE_TO_INTEGER // this is off by default if (is_amount() && ! as_amount().has_commodity() && as_amount().fits_in_long()) { DEBUG_("Reducing amount to integer"); @@ -305,7 +307,7 @@ value_t value_t::number() const if (! as_sequence().empty()) { value_t temp; foreach (const value_t& value, as_sequence()) - temp += value.number(); + temp += value.number(); return temp; } break; @@ -313,7 +315,9 @@ value_t value_t::number() const break; } + add_error_context(_("While calling number() on %1:") << *this); throw_(value_error, _("Cannot determine numeric value of %1") << label()); + return false; } @@ -329,16 +333,17 @@ value_t& value_t::operator+=(const value_t& val) else if (is_sequence()) { if (val.is_sequence()) { if (size() == val.size()) { - sequence_t::iterator i = begin(); - sequence_t::const_iterator j = val.begin(); + sequence_t::iterator i = begin(); + sequence_t::const_iterator j = val.begin(); - for (; i != end(); i++, j++) - *i += *j; + for (; i != end(); i++, j++) + *i += *j; } else { - throw_(value_error, _("Cannot add sequences of different lengths")); + add_error_context(_("While adding %1 to %2:") << *this << val); + throw_(value_error, _("Cannot add sequences of different lengths")); } } else { - as_sequence_lval().push_back(val); + as_sequence_lval().push_back(new value_t(val)); } return *this; } @@ -348,12 +353,12 @@ value_t& value_t::operator+=(const value_t& val) switch (val.type()) { case INTEGER: as_datetime_lval() += - time_duration_t(0, 0, static_cast<time_duration_t::sec_type>(val.as_long())); + time_duration_t(0, 0, static_cast<time_duration_t::sec_type>(val.as_long())); return *this; case AMOUNT: as_datetime_lval() += - time_duration_t(0, 0, static_cast<time_duration_t::sec_type> - (val.as_amount().to_long())); + time_duration_t(0, 0, static_cast<time_duration_t::sec_type> + (val.as_amount().to_long())); return *this; default: break; @@ -380,8 +385,8 @@ value_t& value_t::operator+=(const value_t& val) return *this; case AMOUNT: if (val.as_amount().has_commodity()) { - in_place_cast(BALANCE); - return *this += val; + in_place_cast(BALANCE); + return *this += val; } in_place_cast(AMOUNT); as_amount_lval() += val.as_amount(); @@ -399,21 +404,21 @@ value_t& value_t::operator+=(const value_t& val) switch (val.type()) { case INTEGER: if (as_amount().has_commodity()) { - in_place_cast(BALANCE); - return *this += val; + in_place_cast(BALANCE); + return *this += val; } else { - as_amount_lval() += val.as_long(); - return *this; + as_amount_lval() += val.as_long(); + return *this; } break; case AMOUNT: if (as_amount().commodity() != val.as_amount().commodity()) { - in_place_cast(BALANCE); - return *this += val; + in_place_cast(BALANCE); + return *this += val; } else { - as_amount_lval() += val.as_amount(); - return *this; + as_amount_lval() += val.as_amount(); + return *this; } break; @@ -447,7 +452,9 @@ value_t& value_t::operator+=(const value_t& val) break; } + add_error_context(_("While adding %1 to %2:") << *this << val); throw_(value_error, _("Cannot add %1 to %2") << val.label() << label()); + return *this; } @@ -458,18 +465,19 @@ value_t& value_t::operator-=(const value_t& val) if (val.is_sequence()) { if (size() == val.size()) { - sequence_t::iterator i = begin(); - sequence_t::const_iterator j = val.begin(); + sequence_t::iterator i = begin(); + sequence_t::const_iterator j = val.begin(); - for (; i != end(); i++, j++) - *i -= *j; + for (; i != end(); i++, j++) + *i -= *j; } else { - throw_(value_error, _("Cannot subtract sequences of different lengths")); + add_error_context(_("While subtracting %1 to %2:") << *this << val); + throw_(value_error, _("Cannot subtract sequences of different lengths")); } } else { sequence_t::iterator i = std::find(seq.begin(), seq.end(), val); if (i != seq.end()) - seq.erase(i); + seq.erase(i); } return *this; } @@ -479,12 +487,12 @@ value_t& value_t::operator-=(const value_t& val) switch (val.type()) { case INTEGER: as_datetime_lval() -= - time_duration_t(0, 0, static_cast<time_duration_t::sec_type>(val.as_long())); + time_duration_t(0, 0, static_cast<time_duration_t::sec_type>(val.as_long())); return *this; case AMOUNT: as_datetime_lval() -= - time_duration_t(0, 0, static_cast<time_duration_t::sec_type> - (val.as_amount().to_long())); + time_duration_t(0, 0, static_cast<time_duration_t::sec_type> + (val.as_amount().to_long())); return *this; default: break; @@ -528,27 +536,27 @@ value_t& value_t::operator-=(const value_t& val) switch (val.type()) { case INTEGER: if (as_amount().has_commodity()) { - in_place_cast(BALANCE); - *this -= val; - in_place_simplify(); - return *this; + in_place_cast(BALANCE); + *this -= val; + in_place_simplify(); + return *this; } else { - as_amount_lval() -= val.as_long(); - in_place_simplify(); - return *this; + as_amount_lval() -= val.as_long(); + in_place_simplify(); + return *this; } break; case AMOUNT: if (as_amount().commodity() != val.as_amount().commodity()) { - in_place_cast(BALANCE); - *this -= val; - in_place_simplify(); - return *this; + in_place_cast(BALANCE); + *this -= val; + in_place_simplify(); + return *this; } else { - as_amount_lval() -= val.as_amount(); - in_place_simplify(); - return *this; + as_amount_lval() -= val.as_amount(); + in_place_simplify(); + return *this; } break; @@ -586,6 +594,7 @@ value_t& value_t::operator-=(const value_t& val) break; } + add_error_context(_("While subtracting %1 from %2:") << *this << val); throw_(value_error, _("Cannot subtract %1 from %2") << val.label() << label()); return *this; @@ -633,8 +642,8 @@ value_t& value_t::operator*=(const value_t& val) return *this; case BALANCE: if (val.as_balance().single_amount()) { - as_amount_lval() *= val.simplified().as_amount(); - return *this; + as_amount_lval() *= val.simplified().as_amount(); + return *this; } break; default: @@ -649,13 +658,13 @@ value_t& value_t::operator*=(const value_t& val) return *this; case AMOUNT: if (as_balance().single_amount()) { - in_place_simplify(); - as_amount_lval() *= val.as_amount(); - return *this; + in_place_simplify(); + as_amount_lval() *= val.as_amount(); + return *this; } else if (! val.as_amount().has_commodity()) { - as_balance_lval() *= val.as_amount(); - return *this; + as_balance_lval() *= val.as_amount(); + return *this; } break; default: @@ -667,9 +676,7 @@ value_t& value_t::operator*=(const value_t& val) break; } - DEBUG("value.multiply.error", "Left: " << *this); - DEBUG("value.multiply.error", "Right: " << val); - + add_error_context(_("While multiplying %1 with %2:") << *this << val); throw_(value_error, _("Cannot multiply %1 with %2") << label() << val.label()); return *this; @@ -702,19 +709,19 @@ value_t& value_t::operator/=(const value_t& val) return *this; case BALANCE: if (val.as_balance().single_amount()) { - value_t simpler(val.simplified()); - switch (simpler.type()) { - case INTEGER: - as_amount_lval() /= simpler.as_long(); - break; - case AMOUNT: - as_amount_lval() /= simpler.as_amount(); - break; - default: - assert(false); - break; - } - return *this; + value_t simpler(val.simplified()); + switch (simpler.type()) { + case INTEGER: + as_amount_lval() /= simpler.as_long(); + break; + case AMOUNT: + as_amount_lval() /= simpler.as_amount(); + break; + default: + assert(false); + break; + } + return *this; } break; default: @@ -729,13 +736,13 @@ value_t& value_t::operator/=(const value_t& val) return *this; case AMOUNT: if (as_balance().single_amount()) { - in_place_simplify(); - as_amount_lval() /= val.as_amount(); - return *this; + in_place_simplify(); + as_amount_lval() /= val.as_amount(); + return *this; } else if (! val.as_amount().has_commodity()) { - as_balance_lval() /= val.as_amount(); - return *this; + as_balance_lval() /= val.as_amount(); + return *this; } break; default: @@ -747,6 +754,7 @@ value_t& value_t::operator/=(const value_t& val) break; } + add_error_context(_("While dividing %1 by %2:") << *this << val); throw_(value_error, _("Cannot divide %1 by %2") << label() << val.label()); return *this; @@ -832,6 +840,7 @@ bool value_t::is_equal_to(const value_t& val) const break; } + add_error_context(_("While comparing equality of %1 to %2:") << *this << val); throw_(value_error, _("Cannot compare %1 to %2") << label() << val.label()); return *this; @@ -843,16 +852,16 @@ bool value_t::is_less_than(const value_t& val) const case BOOLEAN: if (val.is_boolean()) { if (as_boolean()) { - if (! val.as_boolean()) - return false; - else - return false; + if (! val.as_boolean()) + return false; + else + return false; } else if (! as_boolean()) { - if (! val.as_boolean()) - return false; - else - return true; + if (! val.as_boolean()) + return false; + else + return true; } } break; @@ -884,11 +893,11 @@ bool value_t::is_less_than(const value_t& val) const return as_amount() < val.as_long(); case AMOUNT: if (as_amount().commodity() == val.as_amount().commodity() || - ! as_amount().has_commodity() || - ! val.as_amount().has_commodity()) - return as_amount() < val.as_amount(); + ! as_amount().has_commodity() || + ! val.as_amount().has_commodity()) + return as_amount() < val.as_amount(); else - return commodity_t::compare_by_commodity()(&as_amount(), &val.as_amount()); + return commodity_t::compare_by_commodity()(&as_amount(), &val.as_amount()); default: break; } @@ -899,14 +908,14 @@ bool value_t::is_less_than(const value_t& val) const case INTEGER: case AMOUNT: { if (val.is_nonzero()) - break; + break; bool no_amounts = true; foreach (const balance_t::amounts_map::value_type& pair, - as_balance().amounts) { - if (pair.second >= 0L) - return false; - no_amounts = false; + as_balance().amounts) { + if (pair.second >= 0L) + return false; + no_amounts = false; } return ! no_amounts; } @@ -925,13 +934,13 @@ bool value_t::is_less_than(const value_t& val) const case INTEGER: case AMOUNT: { if (val.is_nonzero()) - break; + break; bool no_amounts = true; foreach (const value_t& value, as_sequence()) { - if (value >= 0L) - return false; - no_amounts = false; + if (value >= 0L) + return false; + no_amounts = false; } return ! no_amounts; } @@ -939,14 +948,14 @@ bool value_t::is_less_than(const value_t& val) const sequence_t::const_iterator i = as_sequence().begin(); sequence_t::const_iterator j = val.as_sequence().begin(); for (; (i != as_sequence().end() && - j != val.as_sequence().end()); i++, j++) { - if (! ((*i) < (*j))) - return false; + j != val.as_sequence().end()); i++, j++) { + if (! ((*i) < (*j))) + return false; } if (i == as_sequence().end()) - return true; + return true; else - return false; + return false; break; } default: @@ -958,6 +967,8 @@ bool value_t::is_less_than(const value_t& val) const break; } + add_error_context(_("While comparing if %1 is less than %2:") + << *this << val); throw_(value_error, _("Cannot compare %1 to %2") << label() << val.label()); return *this; @@ -968,16 +979,16 @@ bool value_t::is_greater_than(const value_t& val) const switch (type()) { if (val.is_boolean()) { if (as_boolean()) { - if (! val.as_boolean()) - return true; - else - return false; + if (! val.as_boolean()) + return true; + else + return false; } else if (! as_boolean()) { - if (! val.as_boolean()) - return false; - else - return false; + if (! val.as_boolean()) + return false; + else + return false; } } break; @@ -1019,14 +1030,14 @@ bool value_t::is_greater_than(const value_t& val) const case INTEGER: case AMOUNT: { if (val.is_nonzero()) - break; + break; bool no_amounts = true; foreach (const balance_t::amounts_map::value_type& pair, - as_balance().amounts) { - if (pair.second <= 0L) - return false; - no_amounts = false; + as_balance().amounts) { + if (pair.second <= 0L) + return false; + no_amounts = false; } return ! no_amounts; } @@ -1045,13 +1056,13 @@ bool value_t::is_greater_than(const value_t& val) const case INTEGER: case AMOUNT: { if (val.is_nonzero()) - break; + break; bool no_amounts = true; foreach (const value_t& value, as_sequence()) { - if (value <= 0L) - return false; - no_amounts = false; + if (value <= 0L) + return false; + no_amounts = false; } return ! no_amounts; } @@ -1059,14 +1070,14 @@ bool value_t::is_greater_than(const value_t& val) const sequence_t::const_iterator i = as_sequence().begin(); sequence_t::const_iterator j = val.as_sequence().begin(); for (; (i != as_sequence().end() && - j != val.as_sequence().end()); i++, j++) { - if (! ((*i) > (*j))) - return false; + j != val.as_sequence().end()); i++, j++) { + if (! ((*i) > (*j))) + return false; } if (i == as_sequence().end()) - return false; + return false; else - return true; + return true; break; } default: @@ -1078,6 +1089,8 @@ bool value_t::is_greater_than(const value_t& val) const break; } + add_error_context(_("While comparing if %1 is greater than %2:") + << *this << val); throw_(value_error, _("Cannot compare %1 to %2") << label() << val.label()); return *this; @@ -1097,7 +1110,7 @@ void value_t::in_place_cast(type_t cast_type) else if (cast_type == SEQUENCE) { sequence_t temp; if (! is_null()) - temp.push_back(*this); + temp.push_back(new value_t(*this)); set_sequence(temp); return; } @@ -1181,21 +1194,21 @@ void value_t::in_place_cast(type_t cast_type) switch (cast_type) { case INTEGER: if (amt.is_null()) - set_long(0L); + set_long(0L); else - set_long(as_amount().to_long()); + set_long(as_amount().to_long()); return; case BALANCE: if (amt.is_null()) - set_balance(balance_t()); + set_balance(balance_t()); else - set_balance(as_amount()); + set_balance(as_amount()); return; case STRING: if (amt.is_null()) - set_string(""); + set_string(""); else - set_string(as_amount().to_string()); + set_string(as_amount().to_string()); return; default: break; @@ -1208,27 +1221,28 @@ void value_t::in_place_cast(type_t cast_type) switch (cast_type) { case AMOUNT: { if (bal.amounts.size() == 1) { - // Because we are changing the current balance value to an amount - // value, and because set_amount takes a reference (and that memory is - // about to be repurposed), we must pass in a copy. - set_amount(amount_t((*bal.amounts.begin()).second)); - return; + // Because we are changing the current balance value to an amount + // value, and because set_amount takes a reference (and that memory is + // about to be repurposed), we must pass in a copy. + set_amount(amount_t((*bal.amounts.begin()).second)); + return; } else if (bal.amounts.size() == 0) { - set_amount(0L); - return; + set_amount(0L); + return; } else { - throw_(value_error, _("Cannot convert %1 with multiple commodities to %2") - << label() << label(cast_type)); + add_error_context(_("While converting %1 to an amount:") << *this); + throw_(value_error, _("Cannot convert %1 with multiple commodities to %2") + << label() << label(cast_type)); } break; } case STRING: if (bal.is_empty()) - set_string(""); + set_string(""); else - set_string(as_balance().to_string()); + set_string(as_balance().to_string()); return; default: break; @@ -1240,8 +1254,8 @@ void value_t::in_place_cast(type_t cast_type) switch (cast_type) { case INTEGER: { if (all(as_string(), is_digit())) { - set_long(lexical_cast<long>(as_string())); - return; + set_long(lexical_cast<long>(as_string())); + return; } break; } @@ -1266,8 +1280,9 @@ void value_t::in_place_cast(type_t cast_type) break; } + add_error_context(_("While converting %1:") << *this); throw_(value_error, - _("Cannot convert %1 to %2") << label() << label(cast_type)); + _("Cannot convert %1 to %2") << label() << label(cast_type)); } void value_t::in_place_negate() @@ -1300,6 +1315,7 @@ void value_t::in_place_negate() break; } + add_error_context(_("While negating %1:") << *this); throw_(value_error, _("Cannot negate %1") << label()); } @@ -1336,6 +1352,7 @@ void value_t::in_place_not() break; } + add_error_context(_("While applying not to %1:") << *this); throw_(value_error, _("Cannot 'not' %1") << label()); } @@ -1365,6 +1382,7 @@ bool value_t::is_realzero() const return ! as_expr(); default: + add_error_context(_("While applying is_realzero to %1:") << *this); throw_(value_error, _("Cannot determine if %1 is really zero") << label()); } return false; @@ -1396,13 +1414,14 @@ bool value_t::is_zero() const return ! as_expr(); default: + add_error_context(_("While applying is_zero to %1:") << *this); throw_(value_error, _("Cannot determine if %1 is zero") << label()); } return false; } value_t value_t::value(const optional<datetime_t>& moment, - const optional<commodity_t&>& in_terms_of) const + const optional<commodity_t&>& in_terms_of) const { switch (type()) { case INTEGER: @@ -1410,13 +1429,13 @@ value_t value_t::value(const optional<datetime_t>& moment, case AMOUNT: if (optional<amount_t> val = - as_amount().value(moment, in_terms_of)) + as_amount().value(moment, in_terms_of)) return *val; return NULL_VALUE; case BALANCE: if (optional<balance_t> bal = - as_balance().value(moment, in_terms_of)) + as_balance().value(moment, in_terms_of)) return *bal; return NULL_VALUE; @@ -1424,6 +1443,7 @@ value_t value_t::value(const optional<datetime_t>& moment, break; } + add_error_context(_("While finding valuation of %1:") << *this); throw_(value_error, _("Cannot find the value of %1") << label()); return NULL_VALUE; } @@ -1440,9 +1460,9 @@ value_t value_t::price() const } } -value_t value_t::exchange_commodities(const std::string& commodities, - const bool add_prices, - const optional<datetime_t>& moment) +value_t value_t::exchange_commodities(const std::string& commodities, + const bool add_prices, + const optional<datetime_t>& moment) { scoped_array<char> buf(new char[commodities.length() + 1]); @@ -1452,11 +1472,11 @@ value_t value_t::exchange_commodities(const std::string& commodities, p; p = std::strtok(NULL, ",")) { if (commodity_t * commodity = - commodity_pool_t::current_pool->parse_price_expression(p, add_prices, - moment)) { + commodity_pool_t::current_pool->parse_price_expression(p, add_prices, + moment)) { value_t result = value(moment, *commodity); if (! result.is_null()) - return result; + return result; } } return *this; @@ -1511,6 +1531,7 @@ value_t value_t::abs() const break; } + add_error_context(_("While taking abs of %1:") << *this); throw_(value_error, _("Cannot abs %1") << label()); return NULL_VALUE; } @@ -1537,6 +1558,7 @@ void value_t::in_place_round() break; } + add_error_context(_("While rounding %1:") << *this); throw_(value_error, _("Cannot set rounding for %1") << label()); } @@ -1562,6 +1584,7 @@ void value_t::in_place_truncate() break; } + add_error_context(_("While truncating %1:") << *this); throw_(value_error, _("Cannot truncate %1") << label()); } @@ -1587,6 +1610,7 @@ void value_t::in_place_floor() break; } + add_error_context(_("While flooring %1:") << *this); throw_(value_error, _("Cannot floor %1") << label()); } @@ -1612,32 +1636,38 @@ void value_t::in_place_unround() break; } + add_error_context(_("While unrounding %1:") << *this); throw_(value_error, _("Cannot unround %1") << label()); } void value_t::annotate(const annotation_t& details) { - if (is_amount()) + if (is_amount()) { as_amount_lval().annotate(details); - else + } else { + add_error_context(_("While attempting to annotate %1:") << *this); throw_(value_error, _("Cannot annotate %1") << label()); + } } bool value_t::has_annotation() const { - if (is_amount()) + if (is_amount()) { return as_amount().has_annotation(); - else + } else { + add_error_context(_("While checking if %1 has annotations:") << *this); throw_(value_error, - _("Cannot determine whether %1 is annotated") << label()); + _("Cannot determine whether %1 is annotated") << label()); + } return false; } annotation_t& value_t::annotation() { - if (is_amount()) + if (is_amount()) { return as_amount_lval().annotation(); - else { + } else { + add_error_context(_("While requesting the annotations of %1:") << *this); throw_(value_error, _("Cannot request annotation of %1") << label()); return as_amount_lval().annotation(); // quiet g++ warning } @@ -1663,7 +1693,7 @@ value_t value_t::strip_annotations(const keep_details_t& what_to_keep) const case SEQUENCE: { sequence_t temp; foreach (const value_t& value, as_sequence()) - temp.push_back(value.strip_annotations(what_to_keep)); + temp.push_back(new value_t(value.strip_annotations(what_to_keep))); return temp; } @@ -1681,9 +1711,9 @@ value_t value_t::strip_annotations(const keep_details_t& what_to_keep) const } void value_t::print(std::ostream& out, - const int first_width, - const int latter_width, - const uint_least8_t flags) const + const int first_width, + const int latter_width, + const uint_least8_t flags) const { if (first_width > 0 && (! is_amount() || as_amount().is_zero()) && @@ -1716,7 +1746,7 @@ void value_t::print(std::ostream& out, case INTEGER: if (flags & AMOUNT_PRINT_COLORIZE && as_long() < 0) justify(out, to_string(), first_width, - flags & AMOUNT_PRINT_RIGHT_JUSTIFY, true); + flags & AMOUNT_PRINT_RIGHT_JUSTIFY, true); else out << as_long(); break; @@ -1728,7 +1758,7 @@ void value_t::print(std::ostream& out, std::ostringstream buf; as_amount().print(buf, flags); justify(out, buf.str(), first_width, flags & AMOUNT_PRINT_RIGHT_JUSTIFY, - flags & AMOUNT_PRINT_COLORIZE && as_amount().sign() < 0); + flags & AMOUNT_PRINT_COLORIZE && as_amount().sign() < 0); } break; } @@ -1753,9 +1783,9 @@ void value_t::print(std::ostream& out, bool first = true; foreach (const value_t& value, as_sequence()) { if (first) - first = false; + first = false; else - out << ", "; + out << ", "; value.print(out, first_width, latter_width, flags); } @@ -1776,6 +1806,7 @@ void value_t::print(std::ostream& out, break; default: + add_error_context(_("While printing %1:") << *this); throw_(value_error, _("Cannot print %1") << label()); } } @@ -1822,14 +1853,14 @@ void value_t::dump(std::ostream& out, const bool relaxed) const foreach (const char& ch, as_string()) { switch (ch) { case '"': - out << "\\\""; - break; + out << "\\\""; + break; case '\\': - out << "\\\\"; - break; + out << "\\\\"; + break; default: - out << ch; - break; + out << ch; + break; } } out << '"'; @@ -1854,9 +1885,9 @@ void value_t::dump(std::ostream& out, const bool relaxed) const bool first = true; foreach (const value_t& value, as_sequence()) { if (first) - first = false; + first = false; else - out << ", "; + out << ", "; value.dump(out, relaxed); } @@ -1884,7 +1915,7 @@ bool value_t::valid() const } bool sort_value_is_less_than(const std::list<sort_value_t>& left_values, - const std::list<sort_value_t>& right_values) + const std::list<sort_value_t>& right_values) { std::list<sort_value_t>::const_iterator left_iter = left_values.begin(); std::list<sort_value_t>::const_iterator right_iter = right_values.begin(); @@ -1892,16 +1923,16 @@ bool sort_value_is_less_than(const std::list<sort_value_t>& left_values, while (left_iter != left_values.end() && right_iter != right_values.end()) { // Don't even try to sort balance values if (! (*left_iter).value.is_balance() && - ! (*right_iter).value.is_balance()) { + ! (*right_iter).value.is_balance()) { DEBUG("value.sort", - " Comparing " << (*left_iter).value << " < " << (*right_iter).value); + " Comparing " << (*left_iter).value << " < " << (*right_iter).value); if ((*left_iter).value < (*right_iter).value) { - DEBUG("value.sort", " is less"); - return ! (*left_iter).inverted; + DEBUG("value.sort", " is less"); + return ! (*left_iter).inverted; } else if ((*left_iter).value > (*right_iter).value) { - DEBUG("value.sort", " is greater"); - return (*left_iter).inverted; + DEBUG("value.sort", " is greater"); + return (*left_iter).inverted; } } left_iter++; right_iter++; diff --git a/src/value.h b/src/value.h index cb3b024a..4dfd591c 100644 --- a/src/value.h +++ b/src/value.h @@ -49,7 +49,7 @@ #ifndef _VALUE_H #define _VALUE_H -#include "balance.h" // includes amount.h +#include "balance.h" // includes amount.h #include "mask.h" namespace ledger { @@ -75,21 +75,21 @@ class expr_t; */ class value_t : public ordered_field_operators<value_t, - equality_comparable<value_t, balance_t, - additive<value_t, balance_t, - multiplicative<value_t, balance_t, - ordered_field_operators<value_t, amount_t, - ordered_field_operators<value_t, double, - ordered_field_operators<value_t, unsigned long, - ordered_field_operators<value_t, long> > > > > > > > + equality_comparable<value_t, balance_t, + additive<value_t, balance_t, + multiplicative<value_t, balance_t, + ordered_field_operators<value_t, amount_t, + ordered_field_operators<value_t, double, + ordered_field_operators<value_t, unsigned long, + ordered_field_operators<value_t, long> > > > > > > > { public: /** * The sequence_t member type abstracts the type used to represent a * resizable "array" of value_t objects. */ - typedef std::deque<value_t> sequence_t; - typedef sequence_t::iterator iterator; + typedef ptr_deque<value_t> sequence_t; + typedef sequence_t::iterator iterator; typedef sequence_t::const_iterator const_iterator; typedef sequence_t::difference_type difference_type; @@ -99,18 +99,18 @@ public: * type_t. */ enum type_t { - VOID, // a null value (i.e., uninitialized) - BOOLEAN, // a boolean - DATETIME, // a date and time (Boost posix_time) - DATE, // a date (Boost gregorian::date) - INTEGER, // a signed integer value - AMOUNT, // a ledger::amount_t - BALANCE, // a ledger::balance_t - STRING, // a string object - MASK, // a regular expression mask - SEQUENCE, // a vector of value_t objects - SCOPE, // a pointer to a scope - EXPR // a pointer to a value expression + VOID, // a null value (i.e., uninitialized) + BOOLEAN, // a boolean + DATETIME, // a date and time (Boost posix_time) + DATE, // a date (Boost gregorian::date) + INTEGER, // a signed integer value + AMOUNT, // a ledger::amount_t + BALANCE, // a ledger::balance_t + STRING, // a string object + MASK, // a regular expression mask + SEQUENCE, // a vector of value_t objects + SCOPE, // a pointer to a scope + EXPR // a pointer to a value expression }; private: @@ -128,18 +128,18 @@ private: * The `type' member holds the value_t::type_t value representing * the type of the object stored. */ - variant<bool, // BOOLEAN - datetime_t, // DATETIME - date_t, // DATE - long, // INTEGER - amount_t, // AMOUNT - balance_t *, // BALANCE - string, // STRING - mask_t, // MASK - sequence_t *, // SEQUENCE - scope_t *, // SCOPE - expr_t * // EXPR - > data; + variant<bool, // BOOLEAN + datetime_t, // DATETIME + date_t, // DATE + long, // INTEGER + amount_t, // AMOUNT + balance_t *, // BALANCE + string, // STRING + mask_t, // MASK + sequence_t *, // SEQUENCE + scope_t *, // SCOPE + expr_t * // EXPR + > data; type_t type; @@ -160,7 +160,7 @@ private: TRACE_CTOR(value_t::storage_t, ""); } - public: // so `checked_delete' can access it + public: // so `checked_delete' can access it /** * Destructor. Must only be called when the reference count has * reached zero. The `destroy' method is used to do the actual @@ -193,16 +193,16 @@ private: */ void acquire() const { DEBUG("value.storage.refcount", - "Acquiring " << this << ", refc now " << refc + 1); + "Acquiring " << this << ", refc now " << refc + 1); VERIFY(refc >= 0); refc++; } void release() const { DEBUG("value.storage.refcount", - "Releasing " << this << ", refc now " << refc - 1); + "Releasing " << this << ", refc now " << refc - 1); VERIFY(refc > 0); if (--refc == 0) - checked_delete(this); + checked_delete(this); } friend inline void intrusive_ptr_add_ref(value_t::storage_t * storage) { @@ -216,15 +216,15 @@ private: DEBUG("value.storage.refcount", "Destroying " << this); switch (type) { case VOID: - return; + return; case BALANCE: - checked_delete(boost::get<balance_t *>(data)); - break; + checked_delete(boost::get<balance_t *>(data)); + break; case SEQUENCE: - checked_delete(boost::get<sequence_t *>(data)); - break; + checked_delete(boost::get<sequence_t *>(data)); + break; default: - break; + break; } data = false; type = VOID; @@ -424,8 +424,8 @@ public: temp.in_place_negate(); return temp; } - void in_place_negate(); // exists for efficiency's sake - void in_place_not(); // exists for efficiency's sake + void in_place_negate(); // exists for efficiency's sake + void in_place_not(); // exists for efficiency's sake value_t operator-() const { return negated(); @@ -466,24 +466,24 @@ public: temp.in_place_reduce(); return temp; } - void in_place_reduce(); // exists for efficiency's sake + void in_place_reduce(); // exists for efficiency's sake value_t unreduced() const { value_t temp(*this); temp.in_place_unreduce(); return temp; } - void in_place_unreduce(); // exists for efficiency's sake + void in_place_unreduce(); // exists for efficiency's sake // Return the "market value" of a given value at a specific time. - value_t value(const optional<datetime_t>& moment = none, - const optional<commodity_t&>& in_terms_of = none) const; + value_t value(const optional<datetime_t>& moment = none, + const optional<commodity_t&>& in_terms_of = none) const; value_t price() const; - value_t exchange_commodities(const std::string& commodities, - const bool add_prices = false, - const optional<datetime_t>& moment = none); + value_t exchange_commodities(const std::string& commodities, + const bool add_prices = false, + const optional<datetime_t>& moment = none); /** * Truth tests. @@ -749,9 +749,9 @@ public: * its underlying type, where possible. If not possible, an * exception is thrown. */ - bool to_boolean() const; - int to_int() const; - long to_long() const; + bool to_boolean() const; + int to_int() const; + long to_long() const; datetime_t to_datetime() const; date_t to_date() const; amount_t to_amount() const; @@ -836,7 +836,7 @@ public: *this = sequence_t(); if (! is_sequence()) in_place_cast(SEQUENCE); - as_sequence_lval().push_front(val); + as_sequence_lval().push_front(new value_t(val)); } void push_back(const value_t& val) { @@ -844,7 +844,7 @@ public: *this = sequence_t(); if (! is_sequence()) in_place_cast(SEQUENCE); - as_sequence_lval().push_back(val); + as_sequence_lval().push_back(new value_t(val)); } void pop_back() { @@ -863,13 +863,13 @@ public: std::size_t new_size = seq.size(); if (new_size == 0) { #if BOOST_VERSION >= 103700 - storage.reset(); + storage.reset(); #else - storage = intrusive_ptr<storage_t>(); + storage = intrusive_ptr<storage_t>(); #endif } else if (new_size == 1) { - *this = seq.front(); + *this = seq.front(); } } } @@ -942,9 +942,9 @@ public: * Printing methods. */ void print(std::ostream& out, - const int first_width = -1, - const int latter_width = -1, - const uint_least8_t flags = AMOUNT_PRINT_NO_FLAGS) const; + const int first_width = -1, + const int latter_width = -1, + const uint_least8_t flags = AMOUNT_PRINT_NO_FLAGS) const; void dump(std::ostream& out, const bool relaxed = true) const; @@ -1011,7 +1011,7 @@ struct sort_value_t }; bool sort_value_is_less_than(const std::list<sort_value_t>& left_values, - const std::list<sort_value_t>& right_values); + const std::list<sort_value_t>& right_values); void to_xml(std::ostream& out, const value_t& value); diff --git a/src/xact.cc b/src/xact.cc index 77a55c66..3b66598c 100644 --- a/src/xact.cc +++ b/src/xact.cc @@ -101,9 +101,9 @@ value_t xact_base_t::magnitude() const foreach (const post_t * post, posts) { if (post->amount.sign() > 0) { if (post->cost) - halfbal += *post->cost; + halfbal += *post->cost; else - halfbal += post->amount; + halfbal += post->amount; } } return halfbal; @@ -126,30 +126,30 @@ bool xact_base_t::finalize() if (! p.is_null()) { DEBUG("xact.finalize", "post must balance = " << p.reduced()); if (! post->cost && post->amount.has_annotation() && - post->amount.annotation().price) { - // If the amount has no cost, but is annotated with a per-unit - // price, use the price times the amount as the cost - post->cost = (*post->amount.annotation().price * - post->amount).unrounded(); - DEBUG("xact.finalize", - "annotation price = " << *post->amount.annotation().price); - DEBUG("xact.finalize", "amount = " << post->amount); - DEBUG("xact.finalize", "priced cost = " << *post->cost); - post->add_flags(POST_COST_CALCULATED); - add_or_set_value(balance, post->cost->rounded().reduced()); + post->amount.annotation().price) { + // If the amount has no cost, but is annotated with a per-unit + // price, use the price times the amount as the cost + post->cost = (*post->amount.annotation().price * + post->amount).unrounded(); + DEBUG("xact.finalize", + "annotation price = " << *post->amount.annotation().price); + DEBUG("xact.finalize", "amount = " << post->amount); + DEBUG("xact.finalize", "priced cost = " << *post->cost); + post->add_flags(POST_COST_CALCULATED); + add_or_set_value(balance, post->cost->rounded().reduced()); } else { - // If the amount was a cost, it very likely has the "keep_precision" - // flag set, meaning commodity display precision is ignored when - // displaying the amount. We never want this set for the balance, - // so we must clear the flag in a temporary to avoid it propagating - // into the balance. - add_or_set_value(balance, p.keep_precision() ? - p.rounded().reduced() : p.reduced()); + // If the amount was a cost, it very likely has the "keep_precision" + // flag set, meaning commodity display precision is ignored when + // displaying the amount. We never want this set for the balance, + // so we must clear the flag in a temporary to avoid it propagating + // into the balance. + add_or_set_value(balance, p.keep_precision() ? + p.rounded().reduced() : p.reduced()); } } else if (null_post) { throw_(std::logic_error, - _("Only one posting with null amount allowed per transaction")); + _("Only one posting with null amount allowed per transaction")); } else { null_post = post; @@ -162,7 +162,7 @@ bool xact_base_t::finalize() DEBUG("xact.finalize", "balance is " << balance.label()); if (balance.is_balance()) DEBUG("xact.finalize", "balance commodity count = " - << balance.as_balance().amounts.size()); + << balance.as_balance().amounts.size()); #endif // If there is only one post, balance against the default account if one has @@ -187,16 +187,16 @@ bool xact_base_t::finalize() post_t * top_post = NULL; foreach (post_t * post, posts) { - if (! post->amount.is_null()) { - if (post->amount.has_annotation()) - top_post = post; - else if (! top_post) - top_post = post; + if (! post->amount.is_null() && post->must_balance()) { + if (post->amount.has_annotation()) + top_post = post; + else if (! top_post) + top_post = post; } if (post->cost && ! post->has_flags(POST_COST_CALCULATED)) { - saw_cost = true; - break; + saw_cost = true; + break; } } @@ -211,50 +211,58 @@ bool xact_base_t::finalize() const amount_t * y = &(*a++).second; if (x->commodity() != top_post->amount.commodity()) { - const amount_t * t = x; - x = y; - y = t; + const amount_t * t = x; + x = y; + y = t; } if (*x && *y) { - DEBUG("xact.finalize", "primary amount = " << *x); - DEBUG("xact.finalize", "secondary amount = " << *y); - - commodity_t& comm(x->commodity()); - amount_t per_unit_cost; - amount_t total_cost; - - foreach (post_t * post, posts) { - if (post != top_post && post->must_balance() && - ! post->amount.is_null() && - post->amount.has_annotation() && - post->amount.annotation().price) { - amount_t temp = *post->amount.annotation().price * post->amount; - if (total_cost.is_null()) { - total_cost = temp; - y = &total_cost; - } else { - total_cost += temp; - } - DEBUG("xact.finalize", "total_cost = " << total_cost); - } - } - per_unit_cost = (*y / *x).abs().unrounded(); - - DEBUG("xact.finalize", "per_unit_cost = " << per_unit_cost); - - foreach (post_t * post, posts) { - const amount_t& amt(post->amount); - - if (post->must_balance() && amt.commodity() == comm) { - balance -= amt; - post->cost = per_unit_cost * amt; - post->add_flags(POST_COST_CALCULATED); - balance += *post->cost; - - DEBUG("xact.finalize", "set post->cost to = " << *post->cost); - } - } + DEBUG("xact.finalize", "primary amount = " << *x); + DEBUG("xact.finalize", "secondary amount = " << *y); + + commodity_t& comm(x->commodity()); + amount_t per_unit_cost; + amount_t total_cost; + const amount_t * prev_y = y; + + foreach (post_t * post, posts) { + if (post != top_post && post->must_balance() && + ! post->amount.is_null() && + post->amount.has_annotation() && + post->amount.annotation().price) { + amount_t temp = *post->amount.annotation().price * post->amount; + if (total_cost.is_null()) { + total_cost = temp; + y = &total_cost; + } + else if (total_cost.commodity() == temp.commodity()) { + total_cost += temp; + } + else { + DEBUG("xact.finalize", + "multiple price commodities, aborting price calc"); + y = prev_y; + break; + } + DEBUG("xact.finalize", "total_cost = " << total_cost); + } + } + per_unit_cost = (*y / *x).abs().unrounded(); + + DEBUG("xact.finalize", "per_unit_cost = " << per_unit_cost); + + foreach (post_t * post, posts) { + const amount_t& amt(post->amount); + + if (post->must_balance() && amt.commodity() == comm) { + balance -= amt; + post->cost = per_unit_cost * amt; + post->add_flags(POST_COST_CALCULATED); + balance += *post->cost; + + DEBUG("xact.finalize", "set post->cost to = " << *post->cost); + } + } } } } @@ -267,39 +275,50 @@ bool xact_base_t::finalize() if (post->amount.commodity() == post->cost->commodity()) throw_(balance_error, - _("A posting's cost must be of a different commodity than its amount")); + _("A posting's cost must be of a different commodity than its amount")); cost_breakdown_t breakdown = commodity_pool_t::current_pool->exchange (post->amount, *post->cost, false, - datetime_t(date(), time_duration(0, 0, 0, 0))); + datetime_t(date(), time_duration(0, 0, 0, 0))); if (post->amount.has_annotation() && - breakdown.basis_cost.commodity() == breakdown.final_cost.commodity()) { + breakdown.basis_cost.commodity() == breakdown.final_cost.commodity()) { if (amount_t gain_loss = breakdown.basis_cost - breakdown.final_cost) { - DEBUG("xact.finalize", "gain_loss = " << gain_loss); - gain_loss.in_place_round(); - DEBUG("xact.finalize", "gain_loss rounds to = " << gain_loss); - - add_or_set_value(balance, gain_loss.reduced()); - - account_t * account; - if (gain_loss.sign() > 0) - account = journal->find_account(_("Equity:Capital Gains")); - else - account = journal->find_account(_("Equity:Capital Losses")); - - post_t * p = new post_t(account, gain_loss, ITEM_GENERATED); - p->set_state(post->state()); - add_post(p); - DEBUG("xact.finalize", "added gain_loss, balance = " << balance); + DEBUG("xact.finalize", "gain_loss = " << gain_loss); + gain_loss.in_place_round(); + DEBUG("xact.finalize", "gain_loss rounds to = " << gain_loss); + + if (post->must_balance()) + add_or_set_value(balance, gain_loss.reduced()); + + account_t * account; + if (gain_loss.sign() > 0) + account = journal->find_account(_("Equity:Capital Gains")); + else + account = journal->find_account(_("Equity:Capital Losses")); + + post_t * p = new post_t(account, gain_loss, ITEM_GENERATED); + p->set_state(post->state()); + if (post->has_flags(POST_VIRTUAL)) { + DEBUG("xact.finalize", "gain_loss came from a virtual post"); + p->add_flags(post->flags() & (POST_VIRTUAL | POST_MUST_BALANCE)); + } + add_post(p); + DEBUG("xact.finalize", "added gain_loss, balance = " << balance); } else { - DEBUG("xact.finalize", "gain_loss would have display as zero"); + DEBUG("xact.finalize", "gain_loss would have display as zero"); } } else { post->amount = breakdown.amount; DEBUG("xact.finalize", "added breakdown, balance = " << balance); } + + if (post->has_flags(POST_COST_FIXATED) && + post->amount.has_annotation() && post->amount.annotation().price) { + DEBUG("xact.finalize", "fixating annotation price"); + post->amount.annotation().add_flags(ANNOTATION_PRICE_FIXATED); + } } if (null_post != NULL) { @@ -313,16 +332,16 @@ bool xact_base_t::finalize() bool first = true; const balance_t& bal(balance.as_balance()); foreach (const balance_t::amounts_map::value_type& pair, bal.amounts) { - if (first) { - null_post->amount = pair.second.negated(); - null_post->add_flags(POST_CALCULATED); - first = false; - } else { - post_t * p = new post_t(null_post->account, pair.second.negated(), - ITEM_GENERATED | POST_CALCULATED); - p->set_state(null_post->state()); - add_post(p); - } + if (first) { + null_post->amount = pair.second.negated(); + null_post->add_flags(POST_CALCULATED); + first = false; + } else { + post_t * p = new post_t(null_post->account, pair.second.negated(), + ITEM_GENERATED | POST_CALCULATED); + p->set_state(null_post->state()); + add_post(p); + } } } else if (balance.is_amount()) { @@ -358,10 +377,10 @@ bool xact_base_t::finalize() foreach (post_t * post, posts) { if (! post->amount.is_null()) { - all_null = false; - post->amount.in_place_reduce(); + all_null = false; + post->amount.in_place_reduce(); } else { - some_null = true; + some_null = true; } post->account->add_post(post); @@ -371,10 +390,10 @@ bool xact_base_t::finalize() } if (all_null) - return false; // ignore this xact completely + return false; // ignore this xact completely else if (some_null) throw_(balance_error, - _("There cannot be null amounts after balancing a transaction")); + _("There cannot be null amounts after balancing a transaction")); } VERIFY(valid()); @@ -400,7 +419,7 @@ bool xact_base_t::verify() // amount. We never want this set for the balance, so we must clear the // flag in a temporary to avoid it propagating into the balance. add_or_set_value(balance, p.keep_precision() ? - p.rounded().reduced() : p.reduced()); + p.rounded().reduced() : p.reduced()); } VERIFY(balance.valid()); @@ -414,7 +433,7 @@ bool xact_base_t::verify() if (post->amount.commodity() == post->cost->commodity()) throw_(amount_error, - _("A posting's cost must be of a different commodity than its amount")); + _("A posting's cost must be of a different commodity than its amount")); } if (! balance.is_null() && ! balance.is_zero()) { @@ -494,7 +513,7 @@ namespace { foreach (post_t * p, post.xact->posts) { bind_scope_t bound_scope(scope, *p); if (expr.calc(bound_scope).to_boolean()) - return true; + return true; } return false; } @@ -509,14 +528,14 @@ namespace { foreach (post_t * p, post.xact->posts) { bind_scope_t bound_scope(scope, *p); if (! expr.calc(bound_scope).to_boolean()) - return false; + return false; } return true; } } expr_t::ptr_op_t xact_t::lookup(const symbol_t::kind_t kind, - const string& name) + const string& name) { if (kind != symbol_t::FUNCTION) return item_t::lookup(kind, name); @@ -582,13 +601,13 @@ namespace { case expr_t::op_t::O_MATCH: if (op->left()->kind == expr_t::op_t::IDENT && - op->left()->as_ident() == "account" && - op->right()->kind == expr_t::op_t::VALUE && - op->right()->as_value().is_mask()) - return op->right()->as_value().as_mask() - .match(post.reported_account()->fullname()); + op->left()->as_ident() == "account" && + op->right()->kind == expr_t::op_t::VALUE && + op->right()->as_value().is_mask()) + return op->right()->as_value().as_mask() + .match(post.reported_account()->fullname()); else - break; + break; case expr_t::op_t::O_NOT: return ! post_pred(op->left(), post); @@ -601,9 +620,9 @@ namespace { case expr_t::op_t::O_QUERY: if (post_pred(op->left(), post)) - return post_pred(op->right()->left(), post); + return post_pred(op->right()->left(), post); else - return post_pred(op->right()->right(), post); + return post_pred(op->right()->right(), post); default: break; @@ -630,109 +649,109 @@ void auto_xact_t::extend_xact(xact_base_t& xact) bool matches_predicate = false; if (try_quick_match) { try { - bool found_memoized_result = false; - if (! memoized_results.empty()) { - std::map<string, bool>::iterator i = - memoized_results.find(initial_post->account->fullname()); - if (i != memoized_results.end()) { - found_memoized_result = true; - matches_predicate = (*i).second; - } - } - - // Since the majority of people who use automated transactions simply - // match against account names, try using a *much* faster version of - // the predicate evaluator. - if (! found_memoized_result) { - matches_predicate = post_pred(predicate.get_op(), *initial_post); - memoized_results.insert - (std::pair<string, bool>(initial_post->account->fullname(), - matches_predicate)); - } + bool found_memoized_result = false; + if (! memoized_results.empty()) { + std::map<string, bool>::iterator i = + memoized_results.find(initial_post->account->fullname()); + if (i != memoized_results.end()) { + found_memoized_result = true; + matches_predicate = (*i).second; + } + } + + // Since the majority of people who use automated transactions simply + // match against account names, try using a *much* faster version of + // the predicate evaluator. + if (! found_memoized_result) { + matches_predicate = post_pred(predicate.get_op(), *initial_post); + memoized_results.insert + (std::pair<string, bool>(initial_post->account->fullname(), + matches_predicate)); + } } catch (...) { - DEBUG("xact.extend.fail", - "The quick matcher failed, going back to regular eval"); - try_quick_match = false; - matches_predicate = predicate(*initial_post); + DEBUG("xact.extend.fail", + "The quick matcher failed, going back to regular eval"); + try_quick_match = false; + matches_predicate = predicate(*initial_post); } } else { matches_predicate = predicate(*initial_post); } if (matches_predicate) { foreach (post_t * post, posts) { - amount_t post_amount; - if (post->amount.is_null()) { - if (! post->amount_expr) - throw_(amount_error, - _("Automated transaction's posting has no amount")); - - bind_scope_t bound_scope(*scope_t::default_scope, *initial_post); - value_t result(post->amount_expr->calc(bound_scope)); - if (result.is_long()) { - post_amount = result.to_amount(); - } else { - if (! result.is_amount()) - throw_(amount_error, - _("Amount expressions must result in a simple amount")); - post_amount = result.as_amount(); - } - } else { - post_amount = post->amount; - } - - amount_t amt; - if (! post_amount.commodity()) - amt = initial_post->amount * post_amount; - else - amt = post_amount; + amount_t post_amount; + if (post->amount.is_null()) { + if (! post->amount_expr) + throw_(amount_error, + _("Automated transaction's posting has no amount")); + + bind_scope_t bound_scope(*scope_t::default_scope, *initial_post); + value_t result(post->amount_expr->calc(bound_scope)); + if (result.is_long()) { + post_amount = result.to_amount(); + } else { + if (! result.is_amount()) + throw_(amount_error, + _("Amount expressions must result in a simple amount")); + post_amount = result.as_amount(); + } + } else { + post_amount = post->amount; + } + + amount_t amt; + if (! post_amount.commodity()) + amt = initial_post->amount * post_amount; + else + amt = post_amount; #if defined(DEBUG_ON) - IF_DEBUG("xact.extend") { - DEBUG("xact.extend", - "Initial post on line " << initial_post->pos->beg_line << ": " - << "amount " << initial_post->amount << " (precision " - << initial_post->amount.precision() << ")"); - - if (initial_post->amount.keep_precision()) - DEBUG("xact.extend", " precision is kept"); - - DEBUG("xact.extend", - "Posting on line " << post->pos->beg_line << ": " - << "amount " << post_amount << ", amt " << amt - << " (precision " << post_amount.precision() - << " != " << amt.precision() << ")"); - - if (post_amount.keep_precision()) - DEBUG("xact.extend", " precision is kept"); - if (amt.keep_precision()) - DEBUG("xact.extend", " amt precision is kept"); - } + IF_DEBUG("xact.extend") { + DEBUG("xact.extend", + "Initial post on line " << initial_post->pos->beg_line << ": " + << "amount " << initial_post->amount << " (precision " + << initial_post->amount.precision() << ")"); + + if (initial_post->amount.keep_precision()) + DEBUG("xact.extend", " precision is kept"); + + DEBUG("xact.extend", + "Posting on line " << post->pos->beg_line << ": " + << "amount " << post_amount << ", amt " << amt + << " (precision " << post_amount.precision() + << " != " << amt.precision() << ")"); + + if (post_amount.keep_precision()) + DEBUG("xact.extend", " precision is kept"); + if (amt.keep_precision()) + DEBUG("xact.extend", " amt precision is kept"); + } #endif // defined(DEBUG_ON) - account_t * account = post->account; - string fullname = account->fullname(); - assert(! fullname.empty()); - - if (contains(fullname, "$account")) { - fullname = regex_replace(fullname, regex("\\$account\\>"), - initial_post->account->fullname()); - while (account->parent) - account = account->parent; - account = account->find_account(fullname); - } - - // Copy over details so that the resulting post is a mirror of - // the automated xact's one. - post_t * new_post = new post_t(account, amt); - new_post->copy_details(*post); - new_post->add_flags(ITEM_GENERATED); - - xact.add_post(new_post); - new_post->account->add_post(new_post); - - if (new_post->must_balance()) - needs_further_verification = true; + account_t * account = post->account; + string fullname = account->fullname(); + assert(! fullname.empty()); + + if (contains(fullname, "$account")) { + fullname = regex_replace(fullname, regex("\\$account\\>"), + initial_post->account->fullname()); + while (account->parent) + account = account->parent; + account = account->find_account(fullname); + } + + // Copy over details so that the resulting post is a mirror of + // the automated xact's one. + post_t * new_post = new post_t(account, amt); + new_post->copy_details(*post); + new_post->add_flags(ITEM_GENERATED); + + xact.add_post(new_post); + new_post->account->add_post(new_post); + + if (new_post->must_balance()) + needs_further_verification = true; } } } @@ -749,7 +768,7 @@ void auto_xact_t::extend_xact(xact_base_t& xact) } void extend_xact_base(journal_t * journal, - xact_base_t& base) + xact_base_t& base) { foreach (auto_xact_t * xact, journal->auto_xacts) xact->extend_xact(base); @@ -797,18 +816,18 @@ void to_xml(std::ostream& out, const xact_t& xact) push_xml y(out, "metadata"); foreach (const item_t::string_map::value_type& pair, *xact.metadata) { if (pair.second.first) { - push_xml z(out, "variable"); - { - push_xml w(out, "key"); - out << y.guard(pair.first); - } - { - push_xml w(out, "value"); - out << y.guard(*pair.second.first); - } + push_xml z(out, "variable"); + { + push_xml w(out, "key"); + out << y.guard(pair.first); + } + { + push_xml w(out, "value"); + to_xml(out, *pair.second.first); + } } else { - push_xml z(out, "tag"); - out << y.guard(pair.first); + push_xml z(out, "tag"); + out << y.guard(pair.first); } } } @@ -106,7 +106,7 @@ class xact_t : public xact_base_t { public: optional<string> code; - string payee; + string payee; xact_t() { TRACE_CTOR(xact_t, ""); @@ -123,7 +123,7 @@ public: string id() const; virtual expr_t::ptr_op_t lookup(const symbol_t::kind_t kind, - const string& name); + const string& name); virtual bool valid() const; @@ -188,7 +188,7 @@ class period_xact_t : public xact_base_t { public: date_interval_t period; - string period_string; + string period_string; period_xact_t() { TRACE_CTOR(period_xact_t, ""); @@ -221,7 +221,7 @@ private: #endif // HAVE_BOOST_SERIALIZATION }; -typedef std::list<xact_t *> xacts_list; +typedef std::list<xact_t *> xacts_list; typedef std::list<auto_xact_t *> auto_xacts_list; typedef std::list<period_xact_t *> period_xacts_list; @@ -43,8 +43,8 @@ namespace ledger { namespace { void xml_account(std::ostream& out, const account_t * acct) { if ((acct->has_xdata() && - acct->xdata().has_flags(ACCOUNT_EXT_VISITED)) || - acct->children_with_flags(ACCOUNT_EXT_VISITED)) { + acct->xdata().has_flags(ACCOUNT_EXT_VISITED)) || + acct->children_with_flags(ACCOUNT_EXT_VISITED)) { out << "<account id=\""; out.width(sizeof(unsigned long) * 2); out.fill('0'); @@ -54,15 +54,15 @@ namespace { out << "<name>" << acct->name << "</name>\n"; value_t total = acct->amount(); if (! total.is_null()) { - out << "<amount>\n"; - to_xml(out, total); - out << "</amount>\n"; + out << "<amount>\n"; + to_xml(out, total); + out << "</amount>\n"; } total = acct->total(); if (! total.is_null()) { - out << "<total>\n"; - to_xml(out, total); - out << "</total>\n"; + out << "<total>\n"; + to_xml(out, total); + out << "</total>\n"; } out << "</account>\n"; } @@ -76,8 +76,8 @@ namespace { foreach (const post_t * post, xact->posts) if (post->has_xdata() && - post->xdata().has_flags(POST_EXT_VISITED)) - to_xml(out, *post); + post->xdata().has_flags(POST_EXT_VISITED)) + to_xml(out, *post); out << "</transaction>\n"; } @@ -115,7 +115,7 @@ void format_xml::operator()(post_t& post) assert(post.xdata().has_flags(POST_EXT_VISITED)); commodities.insert(commodities_pair(post.amount.commodity().symbol(), - &post.amount.commodity())); + &post.amount.commodity())); if (transactions_set.find(post.xact) == transactions_set.end()) transactions.push_back(post.xact); diff --git a/test/UnitTests.cc b/test/UnitTests.cc index 2c5c0406..af3f6311 100644 --- a/test/UnitTests.cc +++ b/test/UnitTests.cc @@ -35,7 +35,7 @@ public: void testInitialization() { assertEqual(std::string("Hello, world!"), - std::string("Hello, world!")); + std::string("Hello, world!")); } private: @@ -61,7 +61,7 @@ int main(int argc, char* argv[]) // Retreive test path from command line first argument. Default to // "" which resolves to the top level suite. std::string testPath = ((argc > index) ? std::string(argv[index]) : - std::string("")); + std::string("")); // Create the event manager and test controller CPPUNIT_NS::TestResult controller; diff --git a/test/UnitTests.h b/test/UnitTests.h index d9314ddf..a7bfcf9e 100644 --- a/test/UnitTests.h +++ b/test/UnitTests.h @@ -6,14 +6,14 @@ #include <cppunit/Portability.h> #define assertDoublesEqual(x,y,z,w) CPPUNIT_ASSERT_DOUBLES_EQUAL_MESSAGE(x,y,z,w) -#define assertEqual(x,y) CPPUNIT_ASSERT_EQUAL(x,y) -#define assertNotEqual(x,y) CPPUNIT_ASSERT((x) != (y)) -#define assertTrue(x) CPPUNIT_ASSERT(x) -#define assertFalse(x) CPPUNIT_ASSERT(! (x)) -#define assertValid(x) CPPUNIT_ASSERT((x).valid()) +#define assertEqual(x,y) CPPUNIT_ASSERT_EQUAL(x,y) +#define assertNotEqual(x,y) CPPUNIT_ASSERT((x) != (y)) +#define assertTrue(x) CPPUNIT_ASSERT(x) +#define assertFalse(x) CPPUNIT_ASSERT(! (x)) +#define assertValid(x) CPPUNIT_ASSERT((x).valid()) #define assertEqualMessage(x,y,z) CPPUNIT_ASSERT_EQUAL_MESSAGE(x,y,z) -#define assertMessage(x,y) CPPUNIT_ASSERT_MESSAGE(x,y) -#define assertThrow(x,y) CPPUNIT_ASSERT_THROW(x,y) +#define assertMessage(x,y) CPPUNIT_ASSERT_MESSAGE(x,y) +#define assertThrow(x,y) CPPUNIT_ASSERT_THROW(x,y) #define internalAmount(x) amount_t::exact(x) diff --git a/test/baseline/opt-anon.test b/test/baseline/opt-anon.test deleted file mode 100644 index 345d981f..00000000 --- a/test/baseline/opt-anon.test +++ /dev/null @@ -1,11 +0,0 @@ -reg --anon -<<< -2007/02/02 RD VMMXX - Assets:Investments:Vanguard:VMMXX 0.350 VMMXX @ $1.00 - Income:Dividends:Vanguard:VMMXX $-0.35 ->>>1 -07-Feb-02 6a93dcb3 da:20:5d:27:988a9c3a 0.350 A 0.350 A - da:1c:b6:27:988a9c3a B-0.35 0.350 A - B-0.35 ->>>2 -=== 0 diff --git a/test/regress/13965214.test b/test/regress/13965214.test index 674d4d7d..29a7278e 100644 --- a/test/regress/13965214.test +++ b/test/regress/13965214.test @@ -3,20 +3,20 @@ reg Y2008 01/30 A - Bank 130 - Income + Bank 130 + Income 02/01 B - Bank 140 - Income + Bank 140 + Income 02/20 C - Bank 150 - Income + Bank 150 + Income 03/01 D - Bank 160 - Income + Bank 160 + Income >>>1 08-Jan-30 A Bank 130 130 Income -130 0 diff --git a/test/regress/5FBF2ED8.test b/test/regress/5FBF2ED8.test index 78df5a6e..ad8454d1 100644 --- a/test/regress/5FBF2ED8.test +++ b/test/regress/5FBF2ED8.test @@ -1,16 +1,16 @@ bal -B <<< -2008/01/01 * Checking balance - Assets:Bank:Checking £0.00 - Equity:Opening Balances +2008/01/01 * Checking balance + Assets:Bank:Checking £0.00 + Equity:Opening Balances -2008/02/02 Salary - Income:Employer £-334.00 - Assets:Bank:Checking $512.85 @@ £334.00 +2008/02/02 Salary + Income:Employer £-334.00 + Assets:Bank:Checking $512.85 @@ £334.00 -2008/03/02 Salary - Income:Employer £-248.07 - Assets:Bank:Checking $404.82 @@ £248.07 +2008/03/02 Salary + Income:Employer £-248.07 + Assets:Bank:Checking $404.82 @@ £248.07 >>>1 £582.07 Assets:Bank:Checking £-582.07 Income:Employer diff --git a/test/regress/86D2BDC4.test b/test/regress/86D2BDC4.test index 8cd51e42..b6d4083c 100644 --- a/test/regress/86D2BDC4.test +++ b/test/regress/86D2BDC4.test @@ -2,7 +2,7 @@ reg -B <<< 2009/06/03 Westjet Expenses:Transportation:Air C$429.80 @ 1.572865 - Expenses:Bank:Fees 2.73 + Expenses:Bank:Fees 2.73 Liabilities:Mastercard >>>1 09-Jun-03 Westjet Ex:Transportation:Air 676.017377 676.017377 diff --git a/test/regress/F559EC12.test b/test/regress/F559EC12.test index c8b686db..d6b2521e 100644 --- a/test/regress/F559EC12.test +++ b/test/regress/F559EC12.test @@ -6,6 +6,7 @@ format "%-12(scrub(amount))" ; This note applies to all postings. :SecondTag: Expenses:Books 20 BOOK @ $10 ; Metadata: Some Value + ; Typed:: $100 + $200 ; :ExampleTag: ; Here follows a note describing the posting. Liabilities:MasterCard $-200.00 @@ -27,6 +28,7 @@ format "%12(scrub(amount))" ; This note applies to all postings. :SecondTag: Expenses:Books 20 BOOK @ $10 ; Metadata: Some Value + ; Typed:: $100 + $200 ; :ExampleTag: ; Here follows a note describing the posting. Liabilities:MasterCard $-200.00 diff --git a/test/unit/t_amount.cc b/test/unit/t_amount.cc index 63d82675..b1c7b837 100644 --- a/test/unit/t_amount.cc +++ b/test/unit/t_amount.cc @@ -249,7 +249,7 @@ void AmountTestCase::testAssignment() assertEqual(x10, x9); assertFalse(x1.is_null()); - x1 = x0; // sets x1 back to uninitialized state + x1 = x0; // sets x1 back to uninitialized state assertTrue(x0.is_null()); assertTrue(x1.is_null()); @@ -699,11 +699,11 @@ void AmountTestCase::testCommoditySubtraction() assertEqual(internalAmount("$123454434148472090.138858329277476789"), x7 - x8); assertEqual(string("$123454434148472090.138858329277476789"), (x7 - x8).to_string()); assertEqual(string("$123454434148472090.14"), - (amount_t("$1.00") * (x7 - x8)).to_string()); + (amount_t("$1.00") * (x7 - x8)).to_string()); assertEqual(internalAmount("$-123454434148472090.138858329277476789"), x8 - x7); assertEqual(string("$-123454434148472090.138858329277476789"), (x8 - x7).to_string()); assertEqual(string("$-123454434148472090.14"), - (amount_t("$1.00") * (x8 - x7)).to_string()); + (amount_t("$1.00") * (x8 - x7)).to_string()); assertValid(x1); assertValid(x2); @@ -743,7 +743,7 @@ void AmountTestCase::testIntegerMultiplication() amount_t x4("123456789123456789123456789"); assertEqual(amount_t("15241578780673678546105778281054720515622620750190521"), - x4 * x4); + x4 * x4); assertValid(x1); assertValid(y1); @@ -780,7 +780,7 @@ void AmountTestCase::testFractionalMultiplication() amount_t x2("123456789123456789.123456789123456789"); assertEqual(amount_t("15241578780673678546105778311537878.046486820281054720515622620750190521"), - x2 * x2); + x2 * x2); assertValid(x1); assertValid(y1); @@ -835,7 +835,7 @@ void AmountTestCase::testCommodityMultiplication() amount_t x7(internalAmount("$123456789123456789.123456789123456789")); assertEqual(internalAmount("$15241578780673678546105778311537878.046486820281054720515622620750190521"), - x7 * x7); + x7 * x7); assertValid(x1); assertValid(x2); @@ -877,7 +877,7 @@ void AmountTestCase::testIntegerDivision() assertEqual(string("2204585520061728377204585.517857"), (x4 / y4).to_string()); assertEqual(amount_t("0.000000000000000000000000000001"), - amount_t("10") / amount_t("10000000000000000000000000000000")); + amount_t("10") / amount_t("10000000000000000000000000000000")); assertValid(x1); assertValid(y1); @@ -973,9 +973,9 @@ void AmountTestCase::testCommodityDivision() assertEqual(amount_t("$1"), x7 / x7); assertEqual(string("$0.0019216115121765559608381226612019501"), - (x6 / x7).to_fullstring()); + (x6 / x7).to_fullstring()); assertEqual(string("$520.39654928343335571379527154924040947272"), - (x7 / x6).to_fullstring()); + (x7 / x6).to_fullstring()); assertValid(x1); assertValid(x2); @@ -1110,14 +1110,14 @@ void AmountTestCase::testReduction() amount_t x2("600s"); amount_t x3("6000s"); amount_t x4("360000s"); - amount_t x5("10m"); // 600s - amount_t x6("100m"); // 6000s - amount_t x7("1000m"); // 60000s - amount_t x8("10000m"); // 600000s - amount_t x9("10h"); // 36000s - amount_t x10("100h"); // 360000s - amount_t x11("1000h"); // 3600000s - amount_t x12("10000h"); // 36000000s + amount_t x5("10m"); // 600s + amount_t x6("100m"); // 6000s + amount_t x7("1000m"); // 60000s + amount_t x8("10000m"); // 600000s + amount_t x9("10h"); // 36000s + amount_t x10("100h"); // 360000s + amount_t x11("1000h"); // 3600000s + amount_t x12("10000h"); // 36000000s assertThrow(x0.reduce(), amount_error); assertThrow(x0.unreduce(), amount_error); @@ -1220,7 +1220,7 @@ void AmountTestCase::testCommodityForZero() { amount_t x1(internalAmount("$0.000000000000000000001")); - assertTrue(x1); // an internal amount never betrays its precision + assertTrue(x1); // an internal amount never betrays its precision assertFalse(x1.is_zero()); assertFalse(x1.is_realzero()); @@ -1287,7 +1287,7 @@ void AmountTestCase::testPrinting() x1.print(bufstr); assertEqual(std::string("982340823.380238098235098235098235098"), - bufstr.str()); + bufstr.str()); } assertValid(x0); @@ -1304,7 +1304,7 @@ void AmountTestCase::testCommodityPrinting() x1.print(bufstr); assertEqual(std::string("$982340823.386238098235098235098235098"), - bufstr.str()); + bufstr.str()); } { @@ -1312,7 +1312,7 @@ void AmountTestCase::testCommodityPrinting() (x1 * x2).print(bufstr); assertEqual(std::string("$964993493285024293.18099172508158508135413499124"), - bufstr.str()); + bufstr.str()); } { diff --git a/test/unit/t_times.cc b/test/unit/t_times.cc index d8a67b43..aaf31263 100644 --- a/test/unit/t_times.cc +++ b/test/unit/t_times.cc @@ -22,8 +22,8 @@ void DateTimeTestCase::tearDown() void DateTimeTestCase::testConstructors() { #ifndef NOT_FOR_PYTHON - std::time_t now = std::time(NULL); - struct tm * moment = std::localtime(&now); + std::time_t now = std::time(NULL); + struct tm * moment = std::localtime(&now); std::time_t localMoment = std::mktime(moment); #endif // NOT_FOR_PYTHON diff --git a/tools/Makefile.am b/tools/Makefile.am index 42e6a1af..c38f529c 100644 --- a/tools/Makefile.am +++ b/tools/Makefile.am @@ -235,7 +235,7 @@ libledger_python_la_SOURCES = \ libledger_python_la_CPPFLAGS = $(lib_cppflags) -I$(srcdir)/python -pyexec_LTLIBRARIES = ledger.la +pyexec_LTLIBRARIES = ledger.la ledger_la_CPPFLAGS = $(libledger_python_la_CPPFLAGS) ledger_la_SOURCES = src/pyledger.cc @@ -243,7 +243,7 @@ ledger_la_DEPENDENCIES = $(lib_LTLIBRARIES) ledger_la_LDFLAGS = -avoid-version -module ledger_la_LIBADD = $(LIBOBJS) $(lib_LTLIBRARIES) -pkgpython_PYTHON = python/__init__.py python/server.py +pkgpython_PYTHON = python/__init__.py python/server.py endif @@ -408,7 +408,7 @@ ConfirmTests: $(srcdir)/test/ConfirmTests.py GenerateTests_SOURCES = test/GenerateTests.py GenerateTests: $(srcdir)/test/GenerateTests.py - echo "$(PYTHON) $(srcdir)/test/GenerateTests.py $(top_builddir)/ledger$(EXEEXT) $(srcdir) 1 20 \"\$$@\"" > $@ + echo "$(PYTHON) $(srcdir)/test/GenerateTests.py $(top_builddir)/ledger$(EXEEXT) $(srcdir) 1 ${1:-20} \"\$$@\"" > $@ chmod 755 $@ FULLCHECK=$(srcdir)/test/fullcheck.sh @@ -433,13 +433,14 @@ endif fullcheck: cppunittests @$(top_builddir)/RegressTests --verify @$(top_builddir)/BaselineTests --verify - @$(top_builddir)/ManualTests --verify + @$(top_builddir)/ManualTests --verify @$(top_builddir)/ConfirmTests --verify - @$(top_builddir)/GenerateTests --verify + @$(top_builddir)/GenerateTests 20 --verify @$(top_builddir)/RegressTests --gmalloc @$(top_builddir)/BaselineTests --gmalloc - @$(top_builddir)/ManualTests --gmalloc -# @$(top_builddir)/ConfirmTests --gmalloc + @$(top_builddir)/ManualTests --gmalloc + @$(top_builddir)/ConfirmTests --gmalloc + @$(top_builddir)/GenerateTests 10000 # @$(top_builddir)/GenerateTests --gmalloc ###################################################################### diff --git a/tools/configure.ac b/tools/configure.ac index c0a03249..e3149a18 100644 --- a/tools/configure.ac +++ b/tools/configure.ac @@ -65,6 +65,16 @@ AC_ARG_ENABLE(doxygen, AM_CONDITIONAL(USE_DOXYGEN, test x$doxygen = xtrue) +AC_ARG_ENABLE(cache, + [ --enable-cache Enable use of the --cache option], + [case "${enableval}" in + yes) cache=true ;; + no) cache=false ;; + *) AC_MSG_ERROR(bad value ${enableval} for --enable-cache) ;; + esac],[cache=false]) + +AM_CONDITIONAL(USE_CACHE_OPTION, test x$cache = xtrue) + AC_ARG_ENABLE(python, [ --enable-python Turn on Python support (experimental)], [case "${enableval}" in @@ -340,11 +350,11 @@ AC_CACHE_CHECK( AC_LANG_POP LIBS=$boost_serialization_save_libs]) -if [test x$boost_serialization_cpplib_avail_cv_ = xtrue ]; then +if [test x$boost_serialization_cpplib_avail_cv_ = xtrue -a x$cache = xtrue]; then AC_DEFINE([HAVE_BOOST_SERIALIZATION], [1], [Whether Boost.Serialization is available]) LIBS="-lboost_serialization$BOOST_SUFFIX $LIBS" fi -AM_CONDITIONAL(HAVE_BOOST_SERIALIZATION, test x$boost_serialization_cpplib_avail_cv_ = xtrue) +AM_CONDITIONAL(HAVE_BOOST_SERIALIZATION, test x$boost_serialization_cpplib_avail_cv_ = xtrue -a x$cache = xtrue) # check for Python if [ test x$python = xtrue ]; then diff --git a/tools/pre-commit b/tools/pre-commit index 50a32dbd..db47cc45 100755 --- a/tools/pre-commit +++ b/tools/pre-commit @@ -1,4 +1,4 @@ -#!/bin/sh +#!/bin/bash # Exit with status 1 if any command below fails set -e @@ -12,6 +12,9 @@ fi # These are the locations I keep my temporary source and build trees in PRODUCTS=$(./acprep products) # generates a build directory name such as # ~/Products/ledger +if echo $PRODUCTS | grep -qv ledger; then + PRODUCTS=$PRODUCTS/ledger +fi TMPDIR=$PRODUCTS/pre-commit MIRROR=$PRODUCTS/pre-commit-mirror @@ -56,6 +59,7 @@ fi # Finally, (re)build this proposed source tree and see if it passes # muster. + if [ -f acprep ]; then nice -n 20 ./acprep default --warn make check else diff --git a/tools/proof b/tools/proof index 5a329a50..755c3fe7 100755 --- a/tools/proof +++ b/tools/proof @@ -12,17 +12,18 @@ if [[ -f ~/Products/last-proofed && \ exit 0 fi -rm -fr ~/Products/ledger* +rm -fr ~/Products/ledger-proof -time ./acprep --universal -j16 --warn proof 2>&1 | \ +time ./acprep --enable-cache --enable-doxygen \ + --universal -j16 --warn proof 2>&1 | \ tee ~/Desktop/proof.log if egrep -q '(ERROR|CRITICAL)' ~/Desktop/proof.log; then if [[ "$1" = "--alert" ]]; then - notify "Ledger proof build FAILED" + notify "Ledger proof build FAILED" else - echo "Ledger proof build FAILED" - exit 1 + echo "Ledger proof build FAILED" + exit 1 fi else echo "Ledger proof build succeeded" @@ -10,6 +10,8 @@ git checkout next git rebase master git push git checkout master -./acprep --universal -j16 --warn opt upload +./acprep --enable-cache --universal -j16 --warn opt upload +./acprep --enable-cache --universal -j16 --warn opt make speedtest | \ + tee build/last-speed.txt mv *.dmg* build git checkout next |