]> git.pond.sub.org Git - empserver/log
empserver
10 years agoedit: Report unit loss and gain properly for unit key 'O'
Markus Armbruster [Sun, 27 Jan 2013 14:37:51 +0000 (15:37 +0100)]
edit: Report unit loss and gain properly for unit key 'O'

Print a message describing the actual change.  Necessary to give the
deity a chance to catch unexpected changes, e.g. a player boarding a
ship right before the deity edits it.  Watching out for such changes
is especially important with non-interactive edit.

Code already sends bulletins.  Also report news.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Factor out edit_unit()
Markus Armbruster [Sun, 27 Jan 2013 14:22:16 +0000 (15:22 +0100)]
edit: Factor out edit_unit()

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Report ship and land unit commodity change properly
Markus Armbruster [Sun, 3 Feb 2013 12:16:48 +0000 (13:16 +0100)]
edit: Report ship and land unit commodity change properly

Print a message describing the actual change.  Necessary to give the
deity a chance to catch unexpected changes, e.g. a player unloading
stuff right before the deity edits it, leaving fewer items than the
deity intends to take.  Watching out for such changes is especially
important with non-interactive edit.

Send bulletin to owner and report news exactly like the give command.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoactofgod: New divine_unit_change(), similar to divine_sct_change()
Markus Armbruster [Sun, 3 Feb 2013 11:53:03 +0000 (12:53 +0100)]
actofgod: New divine_unit_change(), similar to divine_sct_change()

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoactofgod: Factor report_divine_gift() out of give()
Markus Armbruster [Sun, 3 Feb 2013 11:24:32 +0000 (12:24 +0100)]
actofgod: Factor report_divine_gift() out of give()

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit &c: Report sector non-change differently
Markus Armbruster [Sun, 3 Feb 2013 09:43:46 +0000 (10:43 +0100)]
edit &c: Report sector non-change differently

Print "unchanged" instead of "changed from X to X".  Affects edit,
setresource, setsector.  Suppress bulletin and news.  Affects only
edit sector key 'L'.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoactofgod: Factor divine_sct_change() out of edit.c
Markus Armbruster [Sun, 3 Feb 2013 07:27:31 +0000 (08:27 +0100)]
actofgod: Factor divine_sct_change() out of edit.c

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Streamline wording of sector change reports slightly
Markus Armbruster [Sun, 3 Feb 2013 06:58:03 +0000 (07:58 +0100)]
edit: Streamline wording of sector change reports slightly

Most places use "FOO of X,Y changed", some use "FOO in X,Y changed",
"FOO in X,Y was changed", "FOO of sector X,Y changed".  Normalize to
the former.

Most places do not end the message with a period, some do.  Normalize
to no period.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agosect: Catch clobbered sector coordinates in sct_prewrite()
Markus Armbruster [Sun, 27 Jan 2013 09:31:49 +0000 (10:31 +0100)]
sect: Catch clobbered sector coordinates in sct_prewrite()

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoef_verify: Cover sector coordinates in game state verification
Markus Armbruster [Sun, 27 Jan 2013 09:27:36 +0000 (10:27 +0100)]
ef_verify: Cover sector coordinates in game state verification

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agosctoff2xy(): New, factored out of sct_oninit()
Markus Armbruster [Sun, 27 Jan 2013 09:22:03 +0000 (10:22 +0100)]
sctoff2xy(): New, factored out of sct_oninit()

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoxy.h: Move declaration of sctoff() from sect.h to xy.h
Markus Armbruster [Sun, 27 Jan 2013 09:13:11 +0000 (10:13 +0100)]
xy.h: Move declaration of sctoff() from sect.h to xy.h

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Fix stack smash in sector key 'L'
Markus Armbruster [Sun, 27 Jan 2013 08:28:34 +0000 (09:28 +0100)]
edit: Fix stack smash in sector key 'L'

Key 'L' copies the source sector to a destination sector.  Bug: it
doesn't copy, it messes up the source sector badly instead, and can
smash the stack on some machines.

Root cause: doland() passes &sect instead of sect to ef_set_uid().
Impact:

1. ef_setuid() clobbers a few bytes at &sect.

   When the bitfield and uid fit into sizeof(sect) bytes, it clobbers
   just sect, which has no effect, because doland() returns without
   using it again.  This is the case on a typical 64-bit machine: bit
   field and uid are both 4 bytes, sizeof(sect) is 8.

   When they don't fit, whatever is adjacent to sect gets clobbered.
   On a typical 32-bit machine with stack growing down, that's p.
   Again, no effect, because doland() returns without using it again.
   With stack growing up, it could well be the return address,
   crashing the server.

2. ef_setuid() fails to update *sect.  Impact (when we survive 1):

   sect->sct_uid remains unchanged.  putsect() writes to the source
   sector instead of the destination sector, clobbering the source's
   sct_x, sct_y.  Breaks invariant sctoff(sct_x, sct_y) == sct_uid!
   Subsequent edits are all applied to the source sector.

   sect->sct_seqno remains unchanged.  No effect, because we write to
   the source sector, and the unchanged sequence number is the right
   one there.

Broken in commit 536ef0b0, v4.3.15.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoswapsector: Notify affected sector owners
Markus Armbruster [Sat, 26 Jan 2013 22:18:01 +0000 (23:18 +0100)]
swapsector: Notify affected sector owners

Send bulletins, like edit does.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agosetsector setresource: Switch to edit_sect()
Markus Armbruster [Sat, 26 Jan 2013 14:54:54 +0000 (15:54 +0100)]
setsector setresource: Switch to edit_sect()

One copy of the code suffices.

"Fertility content" becomes just "Fertility" in messages.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Parse int values in edit_FOO() helpers rather than edit()
Markus Armbruster [Sat, 26 Jan 2013 11:28:36 +0000 (12:28 +0100)]
edit: Parse int values in edit_FOO() helpers rather than edit()

Non-integer values are already parsed there.  Treating integer values
specially complicates things for no real gain.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoset_coastal: Fix function comment
Markus Armbruster [Sat, 26 Jan 2013 10:47:59 +0000 (11:47 +0100)]
set_coastal: Fix function comment

Screwed up in commit 6db2e6ec, v4.3.8.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit &c: Add remaining missing sector change reporting
Markus Armbruster [Sat, 26 Jan 2013 10:45:18 +0000 (11:45 +0100)]
edit &c: Add remaining missing sector change reporting

edit, setresource and setsector report change in three ways:

* Print a message.

* Send a bulletin to the changed object's owner.  This should be done
  if and only if the change is visible to the owner, e.g. in census or
  xdump.

* Report divine aid in news.  This should be done if and only if a
  bulletin was sent, except for changes that are neither negative nor
  positive, such as changing the distribution sector.

Fix the places that don't get it right for sectors:

    cmd  key    sctstr member   before  after   notes
    -------------------------------------------------
    edit l O    sct_oldown      --      B-
    edit l F    sct_fallout     --      BN      1
    edit l M    sct_mines       --      BN      2 3
    edit l D    sct_dist_x,y    --      B-      1
    edit l s    sct_type        --      B-      1
    edit l S    sct_newtype     --      B-      1
    setse ow    sct_own         B-      BN
    setse ol    sct_oldown      --      B-
    setse e     sct_effic       --      BN      2
    setse mo    sct_mobil       --      BN      2
    setse a     sct_avail       --      BN      2
    setse w     sct_work        --      BN      2

The two characters in columns before, after show whether the command
sends a bulletin (B) or not (-), and whether it reports news (N) or
not (-).

Notes:

1. Printed message massaged slightly for consistency with other keys.

2. Printed message improved to show the old value, too.  Necessary to
   give the deity a chance to catch unexpected changes, e.g. a player
   laying mines right before the deity edits them.  Watching out for
   such changes is especially important with non-interactive edit.

3. Bulletin and news suppressed for occupied sectors.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Report sector loss and gain properly for key 'L'
Markus Armbruster [Sat, 26 Jan 2013 07:58:14 +0000 (08:58 +0100)]
edit: Report sector loss and gain properly for key 'L'

Send bulletin to owner and report news exactly like for key 'o'.

Also print a "sector duplicated" message, just for consistency with
other keys.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Limit resources to 100 instead of 127
Markus Armbruster [Fri, 25 Jan 2013 18:30:18 +0000 (19:30 +0100)]
edit: Limit resources to 100 instead of 127

Back in Empire 1, resources were limited consistently: fertility to
120, all others to 100.

When Chainsaw added setresource, consistency was lost: fertility got
limited to 100 there.

Chainsaw 3 changed edit to limit all resources to 127.

Commit 3fcee8dd and commit 8e430ae2 (both v4.3.11) changed fairland
and setsector to limit fertility to 100, matching setresource.

Now only edit remains different.  Change it to finally make things
consistent again.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agosetsector: Clean up read beyond end of string
Markus Armbruster [Thu, 24 Jan 2013 21:01:45 +0000 (22:01 +0100)]
setsector: Clean up read beyond end of string

setsector() reads the first two characters unconditionally.  Wrong if
the first character is NUL.  The second character read isn't actually
used then.  Screwed up in Chainsaw.

When getstarg() returns an empty string, it's always in the buffer
passed as third argument.  Thus, reading the second character is
actually safe.

Clean it up anyway.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoprototypes.h: Fix and complete documentation of src/lib/gen/
Markus Armbruster [Thu, 24 Jan 2013 06:51:41 +0000 (07:51 +0100)]
prototypes.h: Fix and complete documentation of src/lib/gen/

Commit 77e95bd7 (v4.3.12) missed the move of log.c there.  A few
pointers to other headers are missing.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agosetsector setresource: Print effect for unowned sectors, too
Markus Armbruster [Wed, 23 Jan 2013 06:52:45 +0000 (07:52 +0100)]
setsector setresource: Print effect for unowned sectors, too

The "changed from" message has always been suppressed for unowned
sectors.  Makes no sense.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agosetsector: Don't disclose number of landmines to occupier
Markus Armbruster [Mon, 21 Jan 2013 20:44:51 +0000 (21:44 +0100)]
setsector: Don't disclose number of landmines to occupier

When the deity sets the number of mines with setsector, the sector
owner (if any) is told the resulting number of mines.  Even for
occupied sectors, where mines belong to the old owner, and thus
shouldn't be disclosed.  Oops.

Fix setsector not to tell the sector owner anything then.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoRevert "Fix setsector not to disclose number of landmines to occupier"
Markus Armbruster [Mon, 21 Jan 2013 20:40:05 +0000 (21:40 +0100)]
Revert "Fix setsector not to disclose number of landmines to occupier"

Fails to print actual change for occupied sectors.  Broken in v4.3.31.

This reverts commit eb4adc93ffc072da7ab1c561fc84e896b7c70d12.

Conflicts:
    src/lib/commands/setsect.c

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit &c: Suppress bulletins for acts of god to himself
Markus Armbruster [Tue, 22 Jan 2013 21:05:06 +0000 (22:05 +0100)]
edit &c: Suppress bulletins for acts of god to himself

Deities get bulletins when they use edit, give, setsector and
setresource on stuff they own.  Except for POGO, who can't own
anything.

The bulletins are annoying; suppress them.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit &c: Suppress news for acts of god to gods
Markus Armbruster [Tue, 22 Jan 2013 21:12:43 +0000 (22:12 +0100)]
edit &c: Suppress news for acts of god to gods

Option GODNEWS is documented to be about deities giving or taking
things from players.  Nevertheless, edit, give, setsector and
setresource report news of deities meddling with things owned by
deities other than POGO.  Don't.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit &c: Suppress news and bulletins on no-op acts of god
Markus Armbruster [Tue, 22 Jan 2013 20:33:40 +0000 (21:33 +0100)]
edit &c: Suppress news and bulletins on no-op acts of god

give already suppresses when the new value equals the old one, but
edit, setresource and setsector don't.  Make them.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoSend bulletins only from POGO
Markus Armbruster [Mon, 21 Jan 2013 19:58:28 +0000 (20:58 +0100)]
Send bulletins only from POGO

In the beginning, all bulletins came from POGO.  Chainsaw changed edit
and give to send them from the deity using the command.  Its new
command setresource sent from POGO regardless.  Its new command
setsector did both.

Go back to sending them only from POGO.

Some of the affected bulletins don't mention the acting deity.  Reword
them so they do.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: De-duplicate code for commodities on ships and land units
Markus Armbruster [Mon, 21 Jan 2013 19:50:40 +0000 (20:50 +0100)]
edit: De-duplicate code for commodities on ships and land units

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Pass full keys around, not just first characters
Markus Armbruster [Sun, 20 Jan 2013 22:40:10 +0000 (23:40 +0100)]
edit: Pass full keys around, not just first characters

To simplify the next commit.

Changes the error message for unknown keys to show the full key.
Shouldn't matter.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Accept interactive empty key argument again
Markus Armbruster [Sun, 20 Jan 2013 22:39:03 +0000 (23:39 +0100)]
edit: Accept interactive empty key argument again

Empty key arguments work fine when passed as command arguments, but
not interactively.  For example, 'edit s 42 R ""' clears the retreat
path, but in an interactive 'edit s 43', 'R ""' sets it to "".

In Empire 1, omitting the argument made it empty.  Empire 2 turned
that into an error without providing an alternative.

Switch to the common command parser, so that quoting works, and "" is
parsed as empty argument.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Treat blank interactive input like empty input
Markus Armbruster [Sun, 20 Jan 2013 22:38:40 +0000 (23:38 +0100)]
edit: Treat blank interactive input like empty input

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agogive: Report number given when less than requested amount
Markus Armbruster [Sun, 20 Jan 2013 16:38:06 +0000 (17:38 +0100)]
give: Report number given when less than requested amount

Necessary to give the deity a chance to catch unexpected changes,
e.g. a player moving away stuff right before a give command, leaving
fewer items than the deity intends to take.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agogive: Fix integer overflows on silly third arguments
Markus Armbruster [Sun, 20 Jan 2013 15:39:32 +0000 (16:39 +0100)]
give: Fix integer overflows on silly third arguments

give() silently caps the resulting number of items to 0..ITEM_MAX.

However, its test for "< 0" suffers integer overflow on two's
complement machines (i.e. practically everywhere) when the amount
argument is INT_MIN.  give() proceeds as if the result was in range:
it sets the number of items to (short)(n + INT_MIN), telexes the owner
that INT_MIN items were stolen (obviously bogus), and tells the deity
that there are now n + INT_MIN items in X,Y.

On common machines, (short)(n + INT_MIN) == n, i.e. nothing is given.

On an oddball machine with short as wide as int, the cast to short
does nothing, item_prewrite() oopses, and corrects the number of items
to zero.

In both cases, output and telegram lie.

Likewise, its test for "> ITEM_MAX" suffers integer overflow for
sufficiently big amount arguments.  Again, give() proceeds as if the
result was in range: it sets the number of items to (short)(n + amt),
telexes the owner that -amt items were stolen (obviously bogus), and
tells the deity that there are now close to INT_MIN items in X,Y.

On common machines, (short)(n + amt) = n + INT_MAX - amt - 1,
i.e. some items are stolen.

On an oddball machine with short as wide as int, the cast to short
does nothing, item_prewrite() oopses, and corrects the number of items
to zero.

Again, output and telegram lie.

Aside: setsector can suffer similar overflows, but it reports the
resulting change correctly.  Good enough.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Don't permit putting a land unit or plane on two carriers
Markus Armbruster [Wed, 16 Jan 2013 20:07:21 +0000 (21:07 +0100)]
edit: Don't permit putting a land unit or plane on two carriers

Only one of struct lndstr members lnd_ship, lnd_land may be
non-negative.  When a deity screws that up, the server oopses.  Be
nice: when setting one, zap the other.

Same for struct plnstr members pln_ship, pln_land.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Fix integer argument range checking
Markus Armbruster [Wed, 16 Jan 2013 19:53:56 +0000 (20:53 +0100)]
edit: Fix integer argument range checking

Upper bounds corrected:

    cmd  key  struct member   wrong   correct   notes
    -------------------------------------------------
    edit l m  sct_mobil         255       127      1
           t  sct_ptime         255     32767
    edit c b  nat_btu          1024  max_btus
    edit p m  pln_mobil         255       127      1
    edit u F  lnd_harden        255       127    1

Missing bounds supplied, arguments out of bounds are silently clipped
unless noted otherwise:

    cmd  key     struct member   bounds           notes
    ---------------------------------------------------
    edit c t     nat_tgms        0   USHRT_MAX       2
           m     nat_reserve     0   INT_MAX
           T...  nat_level[]     0   infinity
    edit s a     shp_pstage      0   PLG_EXPOSED     3
           b     shp_ptime       0   32767
           M     shp_mobil    -127   127
           c...  shp_item[]      0   load limit      4
    edit u Y     lnd_land       -1   size of table   5
           M     lnd_mobil    -127   127
           S     lnd_ship       -1   size of table   5
           Z     lnd_retreat     0   100
           c...  lnd_item[]      0   load limit      4
    edit p r     pln_range       0   max range
           s     pln_ship       -1   size of table   5
           y     pln_land       -1   size of table   5

Notes:

1. Values between SCHAR_MAX and 255 were cast to signed char, changing
the sign.

2. The real upper bound is the number of telegrams in the mailbox, but
counting them isn't worth it.

3. This check is particularly important, because values out of bounds
make the server refuse to start without -F, and empdump -x warn
"export has errors, not importable as is".

4. Values outside 0..ITEM_MAX got caught and clipped by
item_prewrite().  This check avoids the oops, and tightens the upper
bound for units.

5. Argument out-of-bounds are rejected.  This check is particularly
important, because unit numbers beyond the size of the table trigger
oopses.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Drop pointless doland() variables old, des
Markus Armbruster [Tue, 15 Jan 2013 20:22:39 +0000 (21:22 +0100)]
edit: Drop pointless doland() variables old, des

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Suppress "sunk!" after "taken from you by deity"
Markus Armbruster [Tue, 15 Jan 2013 20:00:44 +0000 (21:00 +0100)]
edit: Suppress "sunk!" after "taken from you by deity"

The fact that the ship wasn't given to anyone is none of the
ex-owner's business.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Fix and unify handling of invalid country numbers
Markus Armbruster [Tue, 15 Jan 2013 19:30:36 +0000 (20:30 +0100)]
edit: Fix and unify handling of invalid country numbers

Negative numbers and numbers greater or equal than MAXNOC are invalid.
edit handles such arguments inconsistently:

    cmd  key  struct member   arg < 0     arg >= MAXNOC
    ---------------------------------------------------
    edit l o  sct_own         reject      MAXNOC - 1
           O  sct_oldown      reject      MAXNOC - 1
           X  sct_che_target  0           MAXNOC - 1
    edit s O  shp_own         cast        skip
    edit u O  lnd_own         cast        skip
    edit p O  pln_own         cast        skip

Legend:

    0           replace arg by 0
    MAXNOC - 1  replace arg by MAXNOC - 1
    reject      command fails
    cast        replace arg by (natid)arg
                bug: can be >= MAXNOC!
    skip        ignore this key and arg
                bug: telexes the owner he lost the unit, which is a lie

Unify to reject.  Matches setsector.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Don't show loyalty, plague stage and time as percentages
Markus Armbruster [Tue, 15 Jan 2013 18:25:40 +0000 (19:25 +0100)]
edit: Don't show loyalty, plague stage and time as percentages

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Show edited planes and land units just like ships
Markus Armbruster [Tue, 15 Jan 2013 18:19:56 +0000 (19:19 +0100)]
edit: Show edited planes and land units just like ships

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Show the edited ship even when its owner is invalid
Markus Armbruster [Mon, 14 Jan 2013 22:23:23 +0000 (23:23 +0100)]
edit: Show the edited ship even when its owner is invalid

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoprnatid: Recover from getnatp() failure
Markus Armbruster [Mon, 14 Jan 2013 22:18:11 +0000 (23:18 +0100)]
prnatid: Recover from getnatp() failure

cname() calls getnatp(), and returns a null pointer when it fails.
Some systems (GNU, Windows) deal gracefully with printing null
strings, others crash.

Because we keep table EF_NATION entirely in memory, getnatp() should
fail only on invalid country number.

Rewrite prnatid() to catch this error and recover.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoprnat() prnatid(): New, common country name (#number) formatting
Markus Armbruster [Mon, 14 Jan 2013 22:15:03 +0000 (23:15 +0100)]
prnat() prnatid(): New, common country name (#number) formatting

prnat() is more convenient when you already got the struct natstr *.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoedit: Rename some of helpers, and reorder parameters
Markus Armbruster [Mon, 14 Jan 2013 22:02:58 +0000 (23:02 +0100)]
edit: Rename some of helpers, and reorder parameters

doland() edits a sector, not a land unit.  That one's called dounit().
Lacks taste.  Call the helper for editing a FOO edit_FOO(), and make
the FOO * the first parameter instead of the last.

Rename the print helpers to print_FOO(), for consistency.  Also frees
up identifier prnat for the next commit.

While there, clean up an unused #define.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoReplace common pattern by new LIMIT_TO()
Markus Armbruster [Mon, 14 Jan 2013 21:34:05 +0000 (22:34 +0100)]
Replace common pattern by new LIMIT_TO()

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agotests/actofgod: New, disabled for now because it oopses
Markus Armbruster [Sat, 1 Jun 2013 10:46:40 +0000 (12:46 +0200)]
tests/actofgod: New, disabled for now because it oopses

This is a fairly comprehensive test of the deity commands to edit game
state: edit, setresource, setsector, give, swapsector.

The test makes edit screw up game state, triggering oopses.  The
server refuses to start without -F then, and empdump -x warns "export
has errors, not importable as is".  Until these bugs are fixed, skip
this test in "make check".

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agomake: Drop unused support for parallel test runs
Markus Armbruster [Sat, 1 Jun 2013 10:44:02 +0000 (12:44 +0200)]
make: Drop unused support for parallel test runs

Tests can't run in parallel anyway, because they use uses a single
sandbox directory and a single TCP port.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoempdump: Don't abort() on unresolvable symbols
Markus Armbruster [Sat, 1 Jun 2013 08:36:33 +0000 (10:36 +0200)]
empdump: Don't abort() on unresolvable symbols

empdump flags them since commit 2a5d12b (v4.3.28), but still aborts.
Avoid the abort.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agotests: Capture player output via journal instead of client
Markus Armbruster [Fri, 31 May 2013 08:41:18 +0000 (10:41 +0200)]
tests: Capture player output via journal instead of client

Capturing the client's output tests both client and server, which is
nice.  However, player input isn't visible in the resulting file,
which makes it more difficult to understand.

Route player output to journal (econfig key "keep_journal 2"), and
ignore client output.

Separate tests for the client would be useful.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoclient: Send login commands without trailing space
Markus Armbruster [Fri, 31 May 2013 08:02:54 +0000 (10:02 +0200)]
client: Send login commands without trailing space

Cosmetical improvement; the server is just fine with trailing space.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agotests: Cut off log file timestamp instead of normalizing it
Markus Armbruster [Fri, 31 May 2013 07:54:50 +0000 (09:54 +0200)]
tests: Cut off log file timestamp instead of normalizing it

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agotests: Enable thread stack checking (emp_server -s)
Markus Armbruster [Fri, 31 May 2013 07:27:09 +0000 (09:27 +0200)]
tests: Enable thread stack checking (emp_server -s)

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agocutoff level: Add FIXME comments to narrow coordinate columns
Markus Armbruster [Sun, 26 May 2013 09:31:21 +0000 (11:31 +0200)]
cutoff level: Add FIXME comments to narrow coordinate columns

When formatting coordinates for fixed-width output, the width should
be at least four characters.

cutoff was fine until 4.0.2 reduced coordinate width to three to make
space for civilian and military delivery thresholds.

level has always used width three.

Can't fix either without making lines too long or dropping
information, so just document the problem for now.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agomission: Widen coordinate columns to four characters
Markus Armbruster [Sun, 26 May 2013 09:08:37 +0000 (11:08 +0200)]
mission: Widen coordinate columns to four characters

When formatting coordinates for fixed-width output, the width should
be at least four characters.

Columns x,y and op-sect use three.  Has always been that way.  Widen
them both to four.  This cleans up output for world sizes between 200
and 1998.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agosorder: Widen coordinate columns to four characters
Markus Armbruster [Sun, 26 May 2013 08:58:23 +0000 (10:58 +0200)]
sorder: Widen coordinate columns to four characters

When formatting coordinates for fixed-width output, the width should
be at least four characters.

Columns x,y, start and end use three.  Has always been that way,
except for end, which used two until commit e07fb30 (v4.2.13).

Widen them all to four.  This cleans up output for world sizes between
200 and 1998.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoland: Separate columns x,y and a in output properly
Markus Armbruster [Sat, 25 May 2013 17:59:19 +0000 (19:59 +0200)]
land: Separate columns x,y and a in output properly

Coordinates run into army when the y coordinate is wider than three
characters.  Has always been broken.  Insert a separating space.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agosatmap: Separate and align columns in output properly
Markus Armbruster [Sat, 25 May 2013 17:37:22 +0000 (19:37 +0200)]
satmap: Separate and align columns in output properly

Land unit coordinates run into efficiency in output of satellite when
the y coordinate is wider than three characters.  Broken in Empire 2.
Restore the separating space.

Both ship and land unit table header aren't aligned with the table
body.  Affects recon and sweep with spy planes, and satellite.  Fix
the header.

Reported-by: William Fittge <ptkei2@gmail.com>
Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agotcp_listen: Plug fd leak on OpenBSD with IPv6
Markus Armbruster [Sat, 25 May 2013 15:08:26 +0000 (17:08 +0200)]
tcp_listen: Plug fd leak on OpenBSD with IPv6

Leaks one file descriptor per configured IPv6 address, which should be
pretty harmless.  Broken in commit da154ff, v4.3.31.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoinfo/version: Update example to current output
Markus Armbruster [Sat, 25 May 2013 15:02:11 +0000 (17:02 +0200)]
info/version: Update example to current output

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoPut URIs and e-mail addresses in <angle brackets>
Markus Armbruster [Sat, 25 May 2013 15:01:05 +0000 (17:01 +0200)]
Put URIs and e-mail addresses in <angle brackets>

Also end URIs with '/' where appropriate.

Refrain from touching scripts/ and Stephen Crane's LWP authorship
note.

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoversion: Consistently end sentences with periods
Markus Armbruster [Sat, 25 May 2013 14:47:55 +0000 (16:47 +0200)]
version: Consistently end sentences with periods

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agodoc/README: Clarify description of file coding
Markus Armbruster [Sat, 25 May 2013 13:51:15 +0000 (15:51 +0200)]
doc/README: Clarify description of file coding

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agodoc/coding: Correct spelling mistakes
Markus Armbruster [Sat, 25 May 2013 13:50:31 +0000 (15:50 +0200)]
doc/coding: Correct spelling mistakes

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agodoc/contributing: New file
Markus Armbruster [Sat, 25 May 2013 13:28:16 +0000 (15:28 +0200)]
doc/contributing: New file

Partly inspired by GNU coreutils HACKING[*].

doc/coding section "git" is now redundant, except for the note on
avoiding whitespace changes.  Move that to section "Code formatting",
and delete section "git".

[*] http://git.savannah.gnu.org/cgit/coreutils.git/plain/HACKING?id=77da73c

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoBump version to 4.3.32
Markus Armbruster [Wed, 15 May 2013 17:28:45 +0000 (19:28 +0200)]
Bump version to 4.3.32

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
10 years agoUpdate change log again for 4.3.31 v4.3.31
Markus Armbruster [Sun, 12 May 2013 16:59:42 +0000 (18:59 +0200)]
Update change log again for 4.3.31

10 years agoFix read beyond end of conditional argument on missing operand
Markus Armbruster [Sun, 12 May 2013 09:55:42 +0000 (11:55 +0200)]
Fix read beyond end of conditional argument on missing operand

nstr_parse_val() interprets argument "" as (empty) identifier, then
returns a pointer right beyond the end of the string.

The argument points into player->argbuf[].  If another argument
follows the conditional, it gets appended to the conditional.  Else,
whatever's left there from previous commands gets appended.  If the
argument is at the very end of player->argbuf[], we parse beyond the
buffer, until we run into a syntax error, or a zero byte.

Since player->argbuf[] is followed by a bunch of pointers, a syntax
error is almost certain.  If we somehow manage to parse all the
pointers and player->lasttime, the runaway parse will end at
player->btused, because that's definitely zero when conditionals get
parsed.

10 years agoDon't put broken links in HTML info pages
Markus Armbruster [Sat, 11 May 2013 14:44:40 +0000 (16:44 +0200)]
Don't put broken links in HTML info pages

Pass the valid info page names to emp2html.pl, and convert only valid
references to links there.

10 years agoTighten up emp2html's info reference recognition
Markus Armbruster [Sat, 11 May 2013 14:20:51 +0000 (16:20 +0200)]
Tighten up emp2html's info reference recognition

Combine the two loops looking for \*QNAME\*U and "info NAME" into one.
Recognize "info NAME" only with the closing '"' to be present.

No change with current info sources.

10 years agoFold subj2html.pl into emp2html.pl
Markus Armbruster [Sat, 11 May 2013 13:49:11 +0000 (15:49 +0200)]
Fold subj2html.pl into emp2html.pl

10 years agoUpdate change log for 4.3.31
Markus Armbruster [Wed, 8 May 2013 18:46:00 +0000 (20:46 +0200)]
Update change log for 4.3.31

10 years agoPermit ships that can drop depth charges, but not fire
Markus Armbruster [Wed, 8 May 2013 18:41:46 +0000 (20:41 +0200)]
Permit ships that can drop depth charges, but not fire

No such ships exist in the stock game.

10 years agoConsistently require guns for dropping depth charges
Markus Armbruster [Wed, 8 May 2013 18:37:36 +0000 (20:37 +0200)]
Consistently require guns for dropping depth charges

The fire command requires at least one gun for depth charging, but
missions and return fire don't.  Has always been that way, except
between 4.0.6 and commit a3ad623 (v4.3.12), when depth charging worked
exactly like gun fire, and guns were consistently required.

Require guns for all ways to drop depth charges.

10 years agoCover configure reporting "terminfo: no" in READMEs
Markus Armbruster [Wed, 8 May 2013 17:19:12 +0000 (19:19 +0200)]
Cover configure reporting "terminfo: no" in READMEs

10 years agoCast time_t to long for printing with %ld
Markus Armbruster [Wed, 8 May 2013 17:13:38 +0000 (19:13 +0200)]
Cast time_t to long for printing with %ld

struct timeval member tv_sec used to be long, but POSIX made it
time_t.

10 years agoInclude <sys/time.h> in lwp.h
Markus Armbruster [Tue, 7 May 2013 17:06:35 +0000 (19:06 +0200)]
Include <sys/time.h> in lwp.h

Missed in commit 08b9455, v4.3.20.  Triggers compiler warnings on
NetBSD 5.1.2.

10 years agoRefresh autoconf macros from autoconf-archive-2013.04.06
Markus Armbruster [Mon, 6 May 2013 18:13:43 +0000 (20:13 +0200)]
Refresh autoconf macros from autoconf-archive-2013.04.06

10 years agoMove auxiliary build tools to build-aux/
Markus Armbruster [Mon, 6 May 2013 18:03:22 +0000 (20:03 +0200)]
Move auxiliary build tools to build-aux/

10 years agoRefresh auxiliary build tools from automake 1.11.6
Markus Armbruster [Mon, 6 May 2013 17:55:05 +0000 (19:55 +0200)]
Refresh auxiliary build tools from automake 1.11.6

10 years agoChange econfig key rollover_avail_max from 0 to 50
Markus Armbruster [Mon, 6 May 2013 17:00:54 +0000 (19:00 +0200)]
Change econfig key rollover_avail_max from 0 to 50

So you don't have to micromanage workers to maximize useful work.

The previous commit made the problem a bit worse.  If you had a few
workers too many before, you perhaps produced an extra unit.  Now, you
get to keep the extra work instead.  Useless, unless it rolls over.

10 years agoMake sector production more predictable
Markus Armbruster [Mon, 6 May 2013 16:58:59 +0000 (18:58 +0200)]
Make sector production more predictable

produce() limits production to how many units the workers can produce,
rounding randomly.  It charges work for the units actually produced,
discarding fractions.

If you get lucky with the random rounding, you may get a bit of extra
work done for free.  Else, you get to keep the unused work, and may
even be undercharged a tiny bit of work.  Has always been that way.

The production command assumes the random rounding rounds up if and
only if the probability to do so is at least 50%.  Thus, it's
frequently off by one for sectors producing at their worker limit.

The budget command runs the update code, and is therefore also off by
one, only differently.

Rather annoying for tech and research centers, where a single unit
matters.  A tech center with full civilian population can produce 37.5
units in 60 etus.  Given enough materials, it'll fluctuate between 37
and 38.  Production consistently predicts 38, and budget randomly
predicts either 37 or 38.  Both are off by one half the time.

Fix this as follows: limit production to the amount the workers can
produce (no rounding).  Work becomes a hard limit, not subject to
random fluctuations.  Randomly round the work charged for actual
production.  On average, this charges exactly the work that's used.

More importantly, production and budget now predict how much gets
produced more accurately.  They're still not exact, as the amount of
work available for production remains slightly random.

This also "fixes" the smoke test on a i686 Debian 6 box for me.  The
root problem is that floating-point subexpressions may either be
computed in double precision or extended precision.  Different
machines (or different compilers, or even different compiler flags)
may use different precision, and get different results.

Example: producing 108 units at one work per unit, sector p.e. 0.4
needs to charge 108 / 0.4 work.  Computed in double precision, this
gets rounded to 270.0, then truncated to 270.  In 80 bit extended
precision, it gets rounded to 269.999999999, then truncated to 269.

With random rounding instead of truncation, the probability for a
different result is vanishingly small.  However, this commit
introduces truncation in another place.  It just happens not to mess
up the smoke test there.  I doubt this is the last time this kind of
problem upsets the smoke test.

10 years agoRearrange produce() and prod() a bit to make them more similar
Markus Armbruster [Sun, 5 May 2013 20:34:59 +0000 (22:34 +0200)]
Rearrange produce() and prod() a bit to make them more similar

10 years agoFactor prod_resource_limit() out of produce() and prod()
Markus Armbruster [Sun, 5 May 2013 15:09:00 +0000 (17:09 +0200)]
Factor prod_resource_limit() out of produce() and prod()

10 years agoAvoid double rounding materials when limiting products made
Markus Armbruster [Sat, 4 May 2013 15:54:37 +0000 (17:54 +0200)]
Avoid double rounding materials when limiting products made

We can make actual = roundavg(material_consume * prodeff) products.

When we reduce actual, we have to reduce material_consume, too.  Code
does that like this:

    material_consume = roundavg(actual' * material_consume / actual)

Double rounding.  Do this instead:

    material_consume = roundavg(actual' / prodeff)

10 years agoUse ITEM_MAX instead of 9999 as production material limit
Markus Armbruster [Sat, 4 May 2013 06:53:03 +0000 (08:53 +0200)]
Use ITEM_MAX instead of 9999 as production material limit

No functional change, as ITEM_MAX is 9999, just cleaner.

10 years agoprod() duplicates materials_cost(), clean up
Markus Armbruster [Fri, 3 May 2013 18:52:02 +0000 (20:52 +0200)]
prod() duplicates materials_cost(), clean up

Rename materials_cost() to prod_materials_cost(), give external
linkage, use it in prod().

10 years agoClean up redundant code in prod()
Markus Armbruster [Fri, 3 May 2013 18:42:51 +0000 (20:42 +0200)]
Clean up redundant code in prod()

10 years agoFix "info Products" on how to query sector type p.e.
Markus Armbruster [Fri, 3 May 2013 18:11:07 +0000 (20:11 +0200)]
Fix "info Products" on how to query sector type p.e.

It's show sect capabilities, not stats.

10 years agoFix xdump nat column ip for connections from "long" IPv6 addresses
Markus Armbruster [Mon, 29 Apr 2013 19:29:51 +0000 (21:29 +0200)]
Fix xdump nat column ip for connections from "long" IPv6 addresses

Broken in commit 3a7d7fa, which enlarged struct natstr member
nat_hostaddr[] from 32 to 46 characters, but neglected to update the
ca_len in nat_ca[].  Consequently, the address is truncated in xdump.
Can also break country * ?ip=... and such, but that's exotic.

10 years agoFix five year old show stopper bugs on big endian hosts
Markus Armbruster [Mon, 29 Apr 2013 19:28:17 +0000 (21:28 +0200)]
Fix five year old show stopper bugs on big endian hosts

emp_server and empdump refuse to start on most big endian hosts,
because ef_verify_config() chokes on mdchr_ca[]:

Config meta uid 0 field type: value 0 is not in symbol table meta-type
Config meta uid 1 field type: value 0 is not in symbol table meta-type
Config meta uid 2 field type: value 0 is not in symbol table meta-type
Config meta uid 3 field type: value 0 is not in symbol table meta-type
Config meta uid 4 field type: value 0 is not in symbol table meta-type

Broken in commit 06a0036 (v4.3.12), which changed struct castr member
ca_type from packed_nsc_type (typedef'ed to char) to enum nsc_type,
but neglected to update the ca_type in mdchr_ca[].

On little endian hosts, the selector reads the least significant byte,
with sign extension.  Happens to work, because the type values are all
sufficiently small integers.

On big endian hosts, the selector reads the most signiciant byte.
which is always zero (NSC_NOTYPE).  Makes ef_verify_config() fail.

Except when sizeof(enum nsc_notype) == 1.  Then selector type works
fine, and ef_verify_config() succeeds, but we run into the next
problem: the same commit also changed member ca_flags from nsc_flags
(typedef'ed to unsigned char) to int without updating the ca_type in
mdchr_ca[].  This breaks "only" xdump meta column flags.

v4.3.12 was released in April 2008.  Either nobody has tried to run a
game on a big endian host since, or all who did gave up quietly,
without reporting the problem.

We clearly need to test on a wider range of machines.

10 years agoFix xdump trade column type on big endian hosts
Markus Armbruster [Mon, 29 Apr 2013 19:24:51 +0000 (21:24 +0200)]
Fix xdump trade column type on big endian hosts

Broken in commit 14ea670 (v4.3.8), which changed struct trdstr member
trd_type from char to short, but neglected to update the ca_type in
trade_ca[].

On little endian hosts, the selector reads the least significant byte,
with sign extension.  Happens to work, because the type values are all
sufficiently small integers.

On big endian hosts, the selector reads the most signiciant byte,
which is always zero (EF_SECTOR).  Messes up xdump trade badly.

10 years agoFix xdump lost column type on big endian hosts
Markus Armbruster [Mon, 29 Apr 2013 19:23:13 +0000 (21:23 +0200)]
Fix xdump lost column type on big endian hosts

Broken in commit 09248d0 (v4.3.8), which changed struct loststr member
lost_type from char to short, but neglected to update the ca_type in
lost_ca[].

On little endian hosts, the selector reads the least significant byte,
with sign extension.  Happens to work, because the type values are all
sufficiently small integers.

On big endian hosts, the selector reads the most signiciant byte,
which is always zero (EF_SECTOR).  Messes up xdump lost badly.  Also
breaks lost * ?type=..., but that's exotic.

10 years agoImprove how mksubj.pl reports malformed .SA argument
Markus Armbruster [Sun, 28 Apr 2013 16:30:41 +0000 (18:30 +0200)]
Improve how mksubj.pl reports malformed .SA argument

10 years ago.SA should come last, make mksubj.pl enforce it
Markus Armbruster [Sun, 28 Apr 2013 16:29:36 +0000 (18:29 +0200)]
.SA should come last, make mksubj.pl enforce it

10 years agoSubject pages confuse topics and subjects, fix
Markus Armbruster [Sun, 28 Apr 2013 16:06:14 +0000 (18:06 +0200)]
Subject pages confuse topics and subjects, fix

Confused since they were added in Empire 2.

10 years agoSlightly less crude "info page is long" decision
Markus Armbruster [Sun, 28 Apr 2013 16:00:25 +0000 (18:00 +0200)]
Slightly less crude "info page is long" decision

"Unusually long" topics are marked with a "!" in subject indexes.
This should use the line count of the formatted page, but that's too
much trouble, so commit 4c0b4c0 (v4.3.27) approximated it by "source
file has more than 9999 bytes".  Change that to "source file has more
than 300 lines".

10 years agoSimplify how mksubj.pl keeps track of the subjects' topics
Markus Armbruster [Sun, 28 Apr 2013 15:45:05 +0000 (17:45 +0200)]
Simplify how mksubj.pl keeps track of the subjects' topics

Extend global variable %Subjects to hold topics.  Drop global
variables %subject and %largest.

10 years agoSimplify how mksubj.pl parses argument of .SA
Markus Armbruster [Sun, 28 Apr 2013 15:05:10 +0000 (17:05 +0200)]
Simplify how mksubj.pl parses argument of .SA

Call parse_see_also() immediately.  Permits eliminating global
variables %see_also and %sanr.