]> granicus.if.org Git - nethack/log
nethack
5 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Mon, 14 Jan 2019 23:09:26 +0000 (18:09 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

5 years ago\#wizmakemap followup
PatR [Mon, 14 Jan 2019 17:28:10 +0000 (09:28 -0800)]
\#wizmakemap followup

Both u_on_rndspot() and losedogs() might result in having a monster
and the hero be at the same location.  Have wiz_makemap() use the
same fixup for that as goto_level().

5 years agomore enums with explicit values
PatR [Mon, 14 Jan 2019 01:19:39 +0000 (17:19 -0800)]
more enums with explicit values

As before, it's an aid to finding things if you're looking for something
by its numeric value.

5 years ago\#wizmakemap update
PatR [Sun, 13 Jan 2019 23:24:08 +0000 (15:24 -0800)]
\#wizmakemap update

The need for resetting lock picking when swapping in a new level made
me wonder whether other things should be reset too, and there were a
bunch:  digging, travel destination, polearm target, being in water,
being swallowed or held, hiding.  Hero placement was ignoring arrival
region.  Also, it turned out to be pretty easy to fix the FIXME about
steed.

5 years agoblocking or unblocking levitation or flight
PatR [Sun, 13 Jan 2019 23:17:40 +0000 (15:17 -0800)]
blocking or unblocking levitation or flight

when level teleporting or digging.  Level teleporting while levitation
was blocked due to being inside solid rock didn't notice that it should
be unblocked until you moved from whatever type of terrain you landed
on (room, for instance) to some other type (such as corridor).  Digging
down to make a pit or hole while inside solid rock converts that spot
to floor so should also check whether to unblock levitation/flying, and
not fall if unblocking occurs.

5 years agowizmakemap should reset lockpicking
Pasi Kallinen [Sun, 13 Jan 2019 15:27:17 +0000 (17:27 +0200)]
wizmakemap should reset lockpicking

5 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Sun, 13 Jan 2019 02:21:42 +0000 (21:21 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

5 years agobz 406/#H4298 revisited
PatR [Sun, 13 Jan 2019 01:43:52 +0000 (17:43 -0800)]
bz 406/#H4298 revisited

Redo the Ft.Ludios entry hack to suppress the lit walls on the left
and top rather than to light the upper-right corner.  Only noticeable
if carrying a lit candle.  Usually, that is.  This simpler hack could
be detected visually from the treasure room side of the walls involved
but normally won't be.

5 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Sat, 12 Jan 2019 06:08:58 +0000 (01:08 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

5 years agoworkaround #H4298/bz 406 - vision glitch
PatR [Sat, 12 Jan 2019 03:08:02 +0000 (19:08 -0800)]
workaround #H4298/bz 406 - vision glitch

The entry chamber for the Fort Ludios level would be completely lit
except for one corner wall if you arrived carrying a lit candle.  The
unlit spot turns out to be correct, it is beyond candle radius, but
spots further away than that were showing up lit.  That's due to them
bordering a lit region on the opposite side and lit regions seem to
be bigger than their specified dimensions.

I tried to make the lit walls be unlit but it wasn't working.  (Making
the lit region be smaller would probably work but might have unintended
consequences when populating the zoo room.  I didn't try that.)  This
makes the unlit corner show up if light hits the spot next to it, so
that it behaves like the other lit walls surrounding that entry area.

I haven't marked the bug report closed because I don't think this is
the proper way to fix this.

5 years agoenum values
PatR [Sat, 12 Jan 2019 01:18:48 +0000 (17:18 -0800)]
enum values

Give the enum lists in several header files explicit values.  Adding
or removing new entries will be more tedious, but doing that is rare
and being able to grep the headers for numeric values in addition to
names is very useful.

rm.h also has a bunch of tabs replaced with spaces.

5 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Fri, 11 Jan 2019 03:45:41 +0000 (22:45 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

5 years agoFix accessing deleted fire trap
Pasi Kallinen [Thu, 10 Jan 2019 19:47:04 +0000 (21:47 +0200)]
Fix accessing deleted fire trap

melt_ice can delete the fire trap, in the case where the trap
is on ice, and a monster carrying a boulder triggers it, then drowns.

mintrap -> minliquid -> mondead -> ... -> mdrop_obj ->
   flooreffects -> boulder_hits_pool -> delfloortrap

5 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Thu, 10 Jan 2019 14:26:27 +0000 (09:26 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

5 years agoSEDUCE=0
PatR [Thu, 10 Jan 2019 11:10:35 +0000 (03:10 -0800)]
SEDUCE=0

When SEDUCE is disabled, instead of swapping attacks in mons[] once,
do it on the fly in getmattk() whenever needed.  That allows mons[]
to become readonly, although this doesn't declare it 'const' because
doing so will require a zillion 'struct permonst *' updates to match.

This seemed trickier than it should be, but that turned out to be
because the old behavior was broken.  Setting SEDUCE=0 in sysconf or
user's own configuration file resulted in all succubus and incubus
attacks being described as monster smiles engagingly or seductively
rather than hitting (while dishing out physical damage).  I didn't
try rebuilding 3.4.3 to see whether this was already broken before
being migrated to SYSCF.

5 years agocharacteristics loss
PatR [Thu, 10 Jan 2019 02:18:11 +0000 (18:18 -0800)]
characteristics loss

A hero run by the fuzzer that has characteristics plummet to 3 and
then sometimes hang around there instead of being recovered by restore
ability is happening because loss that tries to reduce the base value
below 3 lowers the max (peak) value instead, and once that also gets
down to 3, restore ability is no longer able to do anything with it.
This changes an attempt to reduce a characteristic by N points below 3
to reduce it by rn2(N + 1) instead.  That's N/2 on average and a 50%
chance to be 0 when N is 1, so the peak value reached doesn't plummet
to 3 quite to quickly.  It can still drop to that though.

There is a pull request dealing with simplifying attribute handling
and part of it affects the code being changed here, but the bit of
simplification included in this patch doesn't use it.

5 years agomiscellaneous formatting
PatR [Thu, 10 Jan 2019 02:15:43 +0000 (18:15 -0800)]
miscellaneous formatting

Some minor stuff that's been sitting around for a while.

5 years agohero infravision
PatR [Thu, 10 Jan 2019 02:10:55 +0000 (18:10 -0800)]
hero infravision

Take a first step towards making the mons[] array be readonly.
The only other place that updates it is when changing succubus and
incubus AD_SSEX attacks to AD_SEDU ones and that can be handled
via existing getmattk(), but so far has proven to be trickier than
anticipated.

5 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Wed, 9 Jan 2019 14:22:29 +0000 (09:22 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

5 years agoThis is cron-daily v1-Jan-1-2019. guidebook updated: doc/Guidebook.txt
nhw_cron [Wed, 9 Jan 2019 13:44:14 +0000 (08:44 -0500)]
This is cron-daily v1-Jan-1-2019.  guidebook updated: doc/Guidebook.txt

5 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Wed, 9 Jan 2019 11:21:59 +0000 (06:21 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

5 years agomake zeroany, zeromonst, zeroobj 'const'
PatR [Wed, 9 Jan 2019 09:13:01 +0000 (01:13 -0800)]
make zeroany, zeromonst, zeroobj 'const'

They're never modified.  Minor complication:  &zeroobj is used as
a special not-Null-but-not-an-object value in multiple places and
needs to have 'const' removed with a cast in that situation.

5 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Tue, 8 Jan 2019 23:30:04 +0000 (18:30 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

5 years agotravel targetting via keyboard
PatR [Tue, 8 Jan 2019 22:42:54 +0000 (14:42 -0800)]
travel targetting via keyboard

Some phrase substitution in getpos() or its helpers produced
``Pick a target interesting thing in view for travel''
for 'm _', which sounds pretty awkward.  Change that to be
``Pick an interesting thing in view for travel destination''
leaving "target" implied.

For plain '_', typing '!' yielded
``Using a menu to show possible targets.''
but then nothing happened.  Change that to be
``Using a menu to show possible targets for 'm|M', 'o|O', 'd|D',
and 'x|X'.''
to explain when a menu will actually appear.

6 years ago'm ^T' documentation
PatR [Tue, 8 Jan 2019 21:56:59 +0000 (13:56 -0800)]
'm ^T' documentation

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Mon, 7 Jan 2019 23:13:22 +0000 (18:13 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agostale vptrs for obj->{nexthere,ocontainer,ocarry}
PatR [Mon, 7 Jan 2019 04:59:20 +0000 (20:59 -0800)]
stale vptrs for obj->{nexthere,ocontainer,ocarry}

'struct obj' contains a union of mutually exclusive pointers, but
removing an obj from a list wasn't clearing whichever one had been
in use.  If something is removed from a monster's inventory, clear
the object's pointer back to that monster; if something is removed
from a container, clear the object's pointer back to that container;
and whenever something is removed from the floor, clear the pointer
to the object which followed it at that floor location.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Sun, 6 Jan 2019 15:55:37 +0000 (10:55 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agoget_cost_of_shop_item() crash
PatR [Sun, 6 Jan 2019 10:36:41 +0000 (02:36 -0800)]
get_cost_of_shop_item() crash

More shop price determination fallout.  After the most recent change
to get_cost_of_shop_item(), using ':' inside an engulfer carrying at
least one item while inside a shop would try to follow the item's
obj->ocontainer back-link and crash when that led to the engulfing
monster rather than to a container.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Sat, 5 Jan 2019 15:23:24 +0000 (10:23 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agofix #H7865 - shop prices for container contents
PatR [Sat, 5 Jan 2019 11:21:39 +0000 (03:21 -0800)]
fix #H7865 - shop prices for container contents

The recent attempt to have looking inside a container show shop
prices had multiple problems.  Worst one was showing shop prices as
if the hero would be buying for items already owned by the hero.
Item handling inside containers on shop floor was inconsistent:  if
shop was selling those items, they would include a price, but if not
selling--either already owned by hero or shopkeeper didn't care about
them--they were only marked "no charge" if hero owned the container.

This is definitely better but I won't be surprised if other obscure
issues crop up.  Gold inside containers on shop floor is always owned
by the shop (credit is issued if it was owned by the hero) but is not
described as such.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Sat, 5 Jan 2019 03:45:19 +0000 (22:45 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agooptions.c formatting; glob as named fruit
PatR [Sat, 5 Jan 2019 03:03:34 +0000 (19:03 -0800)]
options.c formatting; glob as named fruit

This started out removing one tab and I got carried away.  It moves
some labels to column 2, removes some parentheses where sizeof is
used on strings rather than types, adds or revises several comments,
replaces a couple of 'while' loops which can be simplified as 'for'
loops, and updates named fruit handling.

"glob of black pudding" became "candied glob of black pudding" if used
as a fruit name, but "small glob of black pudding" was used as-is and
became indistinguishable from an actual small glob.  Unless you had
more than one; then you could try to check whether they merged into a
stack or coalesced into a bigger glob (but if neither of those changes
happened, you still couldn't tell which was the glob and which was the
named fruit).

6 years agosrc formatting
PatR [Sat, 5 Jan 2019 02:47:00 +0000 (18:47 -0800)]
src formatting

Remove a couple of tabs, and for the affected files, put 'goto' labels
in column 2 where they're easier to spot.

6 years ago'm ^T' menu fix
PatR [Sat, 5 Jan 2019 02:28:50 +0000 (18:28 -0800)]
'm ^T' menu fix

Fix fuzzer feedback.  The new wizard mode ^T menu had an early return
which bypassed destroy_nhwindow(), leaving the menu around.  Fuzzer
eventually got "No window slots!" panic from tty.  Make sure that the
menu window is torn down fully before returning.

Also, make the normal wizard mode teleportation chioce be preselected
so that not picking anything doesn't lead to an early return any more.
ESC still does though.

6 years agofix github #172 - ^T inconsistencies; add m^T
PatR [Fri, 4 Jan 2019 01:37:00 +0000 (17:37 -0800)]
fix github #172 - ^T inconsistencies; add m^T

Fixes #172

Casting teleport-away via ^T used different requirements for energy,
strength, and hunger than casting it via 'Z'.  The strength and hunger
requirements were more stringent, the energy one more lenient.  When
it rejected a cast attempt due to any of those, it used up the move,
but 'Z' didn't.

When testing my fix, I wanted an easier way than a debugger to control
how ^T interacts with wizard mode, so finally got around to a first
cut at being able to invoke it via wizard mode but not override those
energy/strength/hunger requirements.  It uses the 'm' prefix to ask
for a menu.  'm^T' gives four options about how to teleport.  (There
are other permutations which aren't handled.)

Also noticed while testing:  ^T wouldn't attempt to cast teleport-away
if you didn't know the corresponding spellbook.  'Z' will attempt that
because it is possible to forget a book and still know its spell.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Thu, 3 Jan 2019 16:17:33 +0000 (11:17 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agosortloot vs gems
PatR [Wed, 2 Jan 2019 22:20:53 +0000 (14:20 -0800)]
sortloot vs gems

Some object classes (such as armor and weapons) are split into
"subclasses" when sortloot applies an ordering (for armor, all helms,
then all gloves, then all boots, and so on).  Give gem class subsets.
Simple (1) valueable gem, (2) worthless glass, (3) gray stone, (4) rock
would give away information; instead, factor in discovery state and use
(1) unseen gems and glass ("gem")
(2) seen but undiscovered gems and glass ("blue gem"),
(3) discovered gems ("sapphire"),
(4) discovered glass ("worthless pieced of blue glass"),
(5) unseen gray stones and rocks ("stone"),
(6) seen but undiscovered gray stones ("gray stone"),
(7) discovered gray stones ("touchstone"),
(8) seen rocks ("rock").
If everything happens to be identified, the simpler ordering happens
(via 3, 4, 7, and 8) because the other subsets will be empty.

6 years agocreate_particular long worm tail vs mkclass
PatR [Wed, 2 Jan 2019 21:42:45 +0000 (13:42 -0800)]
create_particular long worm tail vs mkclass

Similar to ^G of 'I' triggering impossible "mkclass found no class 35
monsters", using a leading substring of "long worm tail" (other than
"l" and "long worm") would trigger impossible "mkclass found no class
59 monsters and kill the fuzzer when it escalates impossible to panic.
Tighten up the substring matching.

^G of '~' wasn't affected; it deliberately creates a long worm rather
than the tail of one.  But it was possible to ask for "long worm tail"
as a specific monster type and then override the switch to long worm
when prompted about whether to force the originally specified critter.
I've added a check to prevent that opportunity to override even though
a tail without a head seemed to be harmless.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Wed, 2 Jan 2019 00:51:05 +0000 (19:51 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agoMerge branch 'cron-NetHack-3.6.2-beta01' into NetHack-3.6.2-beta01
nhmall [Wed, 2 Jan 2019 00:50:17 +0000 (19:50 -0500)]
Merge branch 'cron-NetHack-3.6.2-beta01' into NetHack-3.6.2-beta01

6 years agoREADME update
nhmall [Tue, 1 Jan 2019 22:56:21 +0000 (17:56 -0500)]
README update

6 years agoThis is cron-daily v1-Dec-30-2019. levcomp updated: sys/share/lev_comp.h sys/share...
nhw_cron [Tue, 1 Jan 2019 22:19:21 +0000 (17:19 -0500)]
This is cron-daily v1-Dec-30-2019.  levcomp updated: sys/share/lev_comp.h sys/share/lev_yacc.c

6 years agoThis is cron-daily v1-Dec-30-2019. files updated: Files
nhw_cron [Tue, 1 Jan 2019 22:19:19 +0000 (17:19 -0500)]
This is cron-daily v1-Dec-30-2019.  files updated: Files

6 years agoThis is cron-daily v1-Dec-30-2019. guidebook updated: doc/Guidebook.txt
nhw_cron [Tue, 1 Jan 2019 22:19:13 +0000 (17:19 -0500)]
This is cron-daily v1-Dec-30-2019.  guidebook updated: doc/Guidebook.txt

6 years agoThis is cron-daily v1-Dec-30-2019. dgncomp updated: sys/share/dgn_comp.h sys/share...
nhw_cron [Tue, 1 Jan 2019 22:19:11 +0000 (17:19 -0500)]
This is cron-daily v1-Dec-30-2019.  dgncomp updated: sys/share/dgn_comp.h sys/share/dgn_yacc.c

6 years agoupdate for 2019
nhmall [Tue, 1 Jan 2019 16:48:30 +0000 (11:48 -0500)]
update for 2019

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Tue, 1 Jan 2019 13:37:01 +0000 (08:37 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agotweak the Astral Plane level
PatR [Tue, 1 Jan 2019 00:48:14 +0000 (16:48 -0800)]
tweak the Astral Plane level

Even out the difficulty (from one game to another) somewhat.  Instead
of a 75% chance that two large areas will be opened up on the left
and right sides of the arrival area plus 13.5 (avg) * 1.5 (avg) extra
monsters in that region, change to 60% chance that the left side will
be opened up with 7 (avg) * 1.5 (avg) extra monsters and a separate
60% chance that the right side will be opened up with 7 * 1.5 (avg)
extra monsters.  The chance that both sides get opened up drops to
36% but the chance that neither side gets opened drops to 16%, with
difference made up by 24% chance each for just one side or the other.

I was a little surprised that this actually worked.  I hope there's
a less clumsy way to have a loop index.

6 years agoincorrect header
nhmall [Mon, 31 Dec 2018 03:02:42 +0000 (22:02 -0500)]
incorrect header

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Mon, 31 Dec 2018 02:41:30 +0000 (21:41 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agoUnix Makefile
PatR [Mon, 31 Dec 2018 01:39:56 +0000 (17:39 -0800)]
Unix Makefile

Separate the compiler flags used for compiling X11 code from the rest
of CFLAGS.  Affects hints/macosx10.8 and later.

Add an explicit output argument to the generated compile rules.

6 years ago'O' vs bouldersym
PatR [Sun, 30 Dec 2018 23:30:38 +0000 (15:30 -0800)]
'O' vs bouldersym

The 'O' handling for bouldersym was updating the display value for
boulder even if the value had been rejected, and if it still had the
default of '\0', the map would end up with <NUL> characters.  (When
examined via '//' or ';', those matched dummy monster class #0 and
led to the impossible "Alphabet soup: 'an("")'" that was suppressed
yesterday.)

Attempting to set bouldersym to ^@ or \0 would also be rejected as
duplicating a monster symbol.  That is now accepted and used to reset
the boulder symbol to default.  However, other control characters are
also accepted--not due to this patch, they already are, and from a
config file in addition to via 'O'--so bouldersym can still disrupt
the map.  But that's no different from putting control characters
into a symbol set or setting them from config file via S_foo:^C.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Sun, 30 Dec 2018 13:01:30 +0000 (08:01 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agoremove curses date.h dependency in Windows Makefiles
nhmall [Sun, 30 Dec 2018 12:58:39 +0000 (07:58 -0500)]
remove curses date.h dependency in Windows Makefiles

6 years agominor memory leak
PatR [Sun, 30 Dec 2018 04:41:16 +0000 (20:41 -0800)]
minor memory leak

I ran the fuzzer with MONITOR_HEAP enabled and heaputil found a dozen
or so un-free'd allocations, all made by the same dupstr() call in
special_handling() for "symset" and "roguesymset".  (Reproducible with
a few tens of thousands of fuzzer moves, although you have to take
over from the fuzzer and make a clean exit rather than just interrupt
it or there'll be lots of other un-free'd memory.)  I haven't actually
figured out how/why it was leaking, but reorganizing the code has made
the leak go away (according to a couple of even longer fuzzer runs) so
I'm settling for that.

6 years agoalphabet sour warning
PatR [Sun, 30 Dec 2018 04:39:11 +0000 (20:39 -0800)]
alphabet sour warning

A recently added impossible to check for an(Null) and an("") was
triggered by the fuzzer:  Alphabet soup: 'an("")'.  I reproduced it a
couple of times and tracked it do_screen_description(for '/' command)
matching the symbol from mapglyph to monster class #0, a placeholder
with symbol value '\0'.  So mapglyph() returned a symbol of '\0', but
not necessary from showsyms[0 + SYM_OFF_M].

The pager lookup code's monster loop shouldn't have been attempting
to match against class #0, and since this fix I haven't been able to
reproduce the situation again.  But I also didn't trigger it with a
bunch of temporary checks in mapglyph() so don't know what is really
going on under the hood.

6 years agocurses splash/copyright screen, role prompt
PatR [Sun, 30 Dec 2018 02:38:30 +0000 (18:38 -0800)]
curses splash/copyright screen, role prompt

Back out '#include "date.h"' so that cursinit.c won't be recompiled
every time any other file(s) need to be compiled.  It doesn't need
patchlevel.h either.  There is already a straightforward way to fetch
the copyright banner lines from version.c.

The splash screen (ascii art spelling "NetHack" preceding the normal
copyright lines) was invisible when showing white text on white-ish
background.  Make it honor !guicolor.

"Shall I pick a character's role, race, gender and alignment for you?
 [ynaq] (y) " was too wide to accept the answer on the same line on
an 80-column display so "(y) " was placed on the second line.  That's
constructed in the core; change the construction to omit " a" when
using "character" rather than a role name.  (tty shortens it by omitting
the default " (y)"; with " a" gone, it could revert to normal prompt.)

Also a bit of lint cleanup and some reformatting of cursinit.c....

6 years agofix typos in header line so expansion works
keni [Sun, 30 Dec 2018 00:19:30 +0000 (19:19 -0500)]
fix typos in header line so expansion works

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Sat, 29 Dec 2018 17:36:19 +0000 (12:36 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agonttty topten output processing
nhmall [Sat, 29 Dec 2018 17:26:33 +0000 (12:26 -0500)]
nttty topten output processing

switch back to using the safe routines
after tty port exits on Windows console
tty port.

Fixes H7758
1613

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Sat, 29 Dec 2018 13:46:43 +0000 (08:46 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agoX11 on OSX
PatR [Sat, 29 Dec 2018 11:28:07 +0000 (03:28 -0800)]
X11 on OSX

The change to Makefile.src for X11+XPM on linux broke linking X11 on
OSX.  This updates the hints files (except for the -qt one) so that
 make WANT_WIN_X11=1
and
 make WANT_WIN_X11=1 USE_XPM=1
work correctly.

The comment in macosx10.14 about what version(s) it's intended for
and been tested on is just cloned from 10.10 and should be updated.

6 years agoCurses: Remove useless inventory label
Pasi Kallinen [Sat, 29 Dec 2018 11:16:46 +0000 (13:16 +0200)]
Curses: Remove useless inventory label

The inventory window used a line to say "Inventory:", which is pretty
useless, and that was the only window showing such a label.

Also don't duplicate the "Not carrying anything" text from core.

6 years agoX11 USE_XPM lint
PatR [Sat, 29 Dec 2018 11:02:07 +0000 (03:02 -0800)]
X11 USE_XPM lint

6 years agoX11: default to XPM-format tile file and rip screen
Pasi Kallinen [Sat, 29 Dec 2018 05:19:18 +0000 (07:19 +0200)]
X11: default to XPM-format tile file and rip screen

People have been wondering how to change the tiles on the X11
version, and the old default of NetHack-specific binary tile data
isn't directly editable with image editing tools.

Also show in the #version info if xpm and graphic rip are enabled.

6 years agocreate_particular 'I' vs mkclass
PatR [Sat, 29 Dec 2018 03:10:54 +0000 (19:10 -0800)]
create_particular 'I' vs mkclass

The revised mkclass() [actually new mkclass_aligned()] has an extra
check which didn't used to be there, and attempting to create a
monster of class 'I' with ^G triggered impossible "mkclass found no
class 35 monsters" which the fuzzer escalates to panic.

6 years agomemory #stats
PatR [Fri, 28 Dec 2018 23:06:45 +0000 (15:06 -0800)]
memory #stats

obj->oextra->omonst might contain monst->mextra plus mextra->edog, &c.
That was being ignored when summing up memory allocated for objects.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Fri, 28 Dec 2018 17:56:44 +0000 (12:56 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agoyet more Windows Makefile
nhmall [Fri, 28 Dec 2018 17:51:11 +0000 (12:51 -0500)]
yet more Windows Makefile

Now that the dependency lines are corrected for the
correct output files in the Makefile, it revealed a
dependency on a non-existent file.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Fri, 28 Dec 2018 17:37:56 +0000 (12:37 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agoMore Windows Makefile corrections
nhmall [Fri, 28 Dec 2018 17:34:41 +0000 (12:34 -0500)]
More Windows Makefile corrections

6 years agoWindows Makefile updates
nhmall [Fri, 28 Dec 2018 17:29:12 +0000 (12:29 -0500)]
Windows Makefile updates

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Fri, 28 Dec 2018 15:20:47 +0000 (10:20 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agoa couple of source spelling consistencies for /*FALLTHRU*/
nhmall [Fri, 28 Dec 2018 15:08:56 +0000 (10:08 -0500)]
a couple of source spelling consistencies for /*FALLTHRU*/

6 years agocurses - fix count selection not working for PICK_ONE menus.
Tangles [Fri, 28 Dec 2018 14:32:45 +0000 (01:32 +1100)]
curses - fix count selection not working for PICK_ONE menus.

eg: d2b would drop 2 of item b, but using d* to pick from a menu
and then selecting 2b would ignore the count and just drop the
whole stack.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Fri, 28 Dec 2018 14:42:20 +0000 (09:42 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agoFix missing compilation dependency for cursinit.c
Patric Mueller [Fri, 28 Dec 2018 14:21:33 +0000 (15:21 +0100)]
Fix missing compilation dependency for cursinit.c

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Fri, 28 Dec 2018 13:29:26 +0000 (08:29 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agocurses: include date.h
Pasi Kallinen [Fri, 28 Dec 2018 09:33:58 +0000 (11:33 +0200)]
curses: include date.h

This way the curses port will show the version and compile date
on the startup banner, just like tty does.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Fri, 28 Dec 2018 03:44:16 +0000 (22:44 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agofix github issue #170 - stacks of non-missiles
PatR [Fri, 28 Dec 2018 02:36:26 +0000 (18:36 -0800)]
fix github issue #170 - stacks of non-missiles

Fixes #170

Monsters never throw athames or scalpels but some fake player monsters
on the Astral Plane are given those.  Since they're stackable the
quantity usually gets boosted but there's no point in having more than
one if they won't be thrown.

This could have been fixed by letting monsters throw those two items,
but I prevented the quantity from being boosted instead.

6 years agostack merging vs shop pricing
PatR [Thu, 27 Dec 2018 23:37:06 +0000 (15:37 -0800)]
stack merging vs shop pricing

When merging one stack into another and they have different obj->o_id
price adjustments, keep the o_id of whichever one commands the higher
shop price.

6 years agostack splitting vs shop prices
PatR [Thu, 27 Dec 2018 23:01:15 +0000 (15:01 -0800)]
stack splitting vs shop prices

I misread part of the original code and the revision introduced a bug
based on that.  obj->o_id price variations are used for all types of
non-IDed items, not just non-glass gems.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Thu, 27 Dec 2018 22:37:34 +0000 (17:37 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Thu, 27 Dec 2018 22:26:56 +0000 (17:26 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agofix #H7103 - shop pricing
PatR [Thu, 27 Dec 2018 22:12:48 +0000 (14:12 -0800)]
fix #H7103 - shop pricing

Player came across a stack of 2 gray stones in a shop and kicked one.
That one ended up with a different (in his case, lower) price once it
was separate.  This behavior only applies to non-glass gems which add
a price variation derived from internal ID (obj->o_id) number.  Make
splitting stacks always yield the same price per item in the new stack
as was being charged in the old stack by choosing a similar o_id.  Do
it for all splits (that can vary price by ID, so just non-glass gems),
not just ones performed inside shops.

He picked up the lower priced one and dropped it back on the original
higher priced one; the combined stack took on the lower price.  That
will no longer happen if they come from splitting a stack, but this
fix doesn't address merging with different prices when they start out
as separate stacks.  (Unpaid items won't merge in inventory if prices
are different, but shop-owned items will merge on floor.)

6 years agomines luckstone as achievement marker
PatR [Thu, 27 Dec 2018 21:31:42 +0000 (13:31 -0800)]
mines luckstone as achievement marker

It was possible to have the guaranteed luckstone at Mines' End become
merged with a random one and lose its specialness for achievement
tracking.  Mark it 'nomerge' when created and clear that if/when the
achievement is recorded.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Wed, 26 Dec 2018 17:20:14 +0000 (12:20 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agocurses lint
PatR [Wed, 26 Dec 2018 09:45:17 +0000 (01:45 -0800)]
curses lint

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Wed, 26 Dec 2018 03:06:23 +0000 (22:06 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agocontainer_contents() vs show goods
PatR [Wed, 26 Dec 2018 01:07:45 +0000 (17:07 -0800)]
container_contents() vs show goods

Fix another inconsistency with containers in shops:  prices shown when
looking inside.  Apply had them (because shop goods in containers are
flagged as 'unpaid' when hero carries the container), and loot did not
(because they aren't flagged that way).

6 years agobill hero for magic bag explosion
PatR [Wed, 26 Dec 2018 00:52:33 +0000 (16:52 -0800)]
bill hero for magic bag explosion

Exploding a bag of holding on a shop floor didn't bill for shop-owned
contents which got destroyed.  This puts them on the 'Ix' used up list.

6 years agostolen_value() vs containers
PatR [Wed, 26 Dec 2018 00:45:41 +0000 (16:45 -0800)]
stolen_value() vs containers

stolen_value() treated hero-owned container holding shop-owned goods
as free for the taking.

The fix I'm working on which led to discovering this first added
stolen_value() then eventually stopped using it so I don't have an
example of where it is giving the wrong result.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Tue, 25 Dec 2018 21:53:40 +0000 (16:53 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agoprices of items on shop floor
PatR [Tue, 25 Dec 2018 21:48:51 +0000 (13:48 -0800)]
prices of items on shop floor

get_cost_of_item() was giving different information from shop #chat
when dealing with containers owned by hero containing objects owned
by the shop.  And when it was legitimately reporting a price of 0,
doname_with_price() wasn't reporting 'no charge' for items inside a
shop that were owned by hero or that shopkeeper didn't care about.

Extend the shop price reveal to far-look, but only when hero and item
being examined are inside the same shop.

6 years agoMerge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2
nhmall [Tue, 25 Dec 2018 21:26:49 +0000 (16:26 -0500)]
Merge branch 'NetHack-3.6.2-beta01' into NetHack-3.6.2

6 years agosimplify container_contents()
PatR [Tue, 25 Dec 2018 21:05:35 +0000 (13:05 -0800)]
simplify container_contents()

iflags.in_dumplog is accessible even when DUMPLOG is not enabled.

6 years agostatus gold vs symset:Blank
PatR [Tue, 25 Dec 2018 02:43:51 +0000 (18:43 -0800)]
status gold vs symset:Blank

Symset:Blank sets all the map symbols (except STRANGE_OBJECT) to
<space>.  The status lines for !STATUS_HILITES force status to use '$'
instead of ' ' for the prefix before ":1234" for gold, but the status
lines for STATUS_HILITES did not.  tty ended up with ":1234" for gold.
win32 and curses both ignore the prefix and construct their own, but
since win32 uses the map symbol for that it must also be ending up
with ":1234" (I assume; I haven't seen it).  curses is forcing '$' for
the prefix, even on the rogue level.

This attempts to fix win32 without be able to test the result.  I've
left curses alone.

6 years agoformatting: parse_conf_file()
PatR [Tue, 25 Dec 2018 01:50:21 +0000 (17:50 -0800)]
formatting: parse_conf_file()