]> granicus.if.org Git - nethack/log
nethack
6 years agoX11 menu tweaks
PatR [Sun, 28 Oct 2018 02:26:56 +0000 (19:26 -0700)]
X11 menu tweaks

Restore handling for keystrokes on PICK_NONE menus so that scrolling
via keys works for them.  (That handling was disabled as part of the
patch to support MENUCOLORS.)

Enable [cancel] button for all menus.  (That had apparently been
grayed out for PICK_NONE menus since day 1 for X11 windowing.)

6 years agofix Guidebook.tex processing due to wrong brace used
nhmall [Sat, 27 Oct 2018 23:18:27 +0000 (19:18 -0400)]
fix Guidebook.tex processing due to wrong brace used

[36] [37] [38] [39] [40] [41] [42] [43]
! Extra }, or forgotten \endgroup.
l.4602 ``{\tt up}'' and ``(\tt down}
                                    '' set the field attributes for when the...

6 years agoX11: Remove leftover file display stuff
Pasi Kallinen [Sat, 27 Oct 2018 17:47:27 +0000 (20:47 +0300)]
X11: Remove leftover file display stuff

6 years agoX11: Reuse menu code to display files
Pasi Kallinen [Sat, 27 Oct 2018 10:51:32 +0000 (13:51 +0300)]
X11: Reuse menu code to display files

Previously the code used the ASCII Text Athena widgets for displaying
file contents. Unfortunately, the widget made it impossible to control
scrolling or pretty much anything else.

Use the menu code instead, making the file display window behave properly.

6 years agoprovide dungeon location in ^X feedback
PatR [Sat, 27 Oct 2018 10:45:18 +0000 (03:45 -0700)]
provide dungeon location in ^X feedback

Dungeon level wasn't included in ^X output, so it wasn't actually
giving all status fields and attempting to rely on it when turning
off 'status_updates' was leaving a gap in feedback for the player.
Add an extra line to the first section where character's name and
patron deity are reported, giving current location.
|You are in the Dungeons of Doom, on level 5.
or
|You are in the endgame, on the Elemental Plane of Fire.

The information is more explicit than the basic status field, but
you can already get similar information via #overview so it isn't
giving away extra info.

6 years agoanother Guidebook update - mostly NETHACKOPTIONS
PatR [Sat, 27 Oct 2018 07:42:11 +0000 (00:42 -0700)]
another Guidebook update - mostly NETHACKOPTIONS

Move some 'roff macros from Guidebook.mn to new file tmac.nh.

Header for tmac.nh is not being updated, even after explicitly adding
it to .gitattributes.  I'm not sure what I've done wrong.  (I'm using
'git nhadd doc/' here rather than explicit 'git nhadd doc/tmac.nh'.)

In Guidebook.mn, change the ``setenv NETHACKOPTIONS'' example so that
it fits within one line in Guidebook.txt.  (I looked at 3.4.3's
edition of that file and the example went not just beyond the margin
of the formatted text but beyond 80 columns, so wrapped in an ugly
fashion.)  I had previously changed 'autoquiver' to 'color' to shorten
it, now have changed '!autopickup' to '!leg' to show an example of
truncated option name as well as shorten, and also 'fruit:papaya' to
'fruit:lime' to squeeze out the last two columns needed to fit within
the text margin while retaining 'name:Blue Meanie' as requested.
Guidebook.txt shows both NETHACKOPTIONS examples with indentation
suppressed, Guidebook.ps uses normal indentation (evidently using a
narrower font, even with \f(CR (constant-width Roman) to approximate
TeX's \tt, since the indented example fits fine and looks better).

Some Guidebook.tex catchup.  I suspect that lots of bits and bobs
don't match between Guidebook.mn and Guidebook.tex these days.
Particularly quoting and variant font (italics, bold, \tt) usage.
Also the recently added box around the sample screenshot.  This
modifies the screenshot to match Guidebook.mn's, reflecting change
in status field spacing by STATUS_HILITES.

6 years agofix github issue #150 - delayed encumbrance msg
PatR [Fri, 26 Oct 2018 23:35:21 +0000 (16:35 -0700)]
fix github issue #150 - delayed encumbrance msg

Fixes #150

> A very minor one, but there are some situations where your encumbrance
> level can change, but the message (such as '`Your movements are now
> unencumbered.`') isn't given until your next move or turn, even though
> the status line updates immediately.  For example, praying while weak
> and gaining a point of strength.  Picking up or dropping items or
> interacting with containers does _not_ have this problem.

This is usually fixed on a case by case basis.  Any attempt to add
blanket encumbrance check mid-turn (when updating status, for instance)
is sure to introduce message sequencing problems.  Perhaps such a check
could be added at the end of the hero's move....

This fix handles the cases where prayer causes a change to strength:
major: fix starvation, minor: fix weak from hunger, boon: golden glow
(restore strength and satisfy hunger--probably no-ops in this regard
or would have had trouble fixed rather than receive a boon).  Directly
curing stat loss (minor: poisoned) already dealt with encumbrance.

> Possibly related to the quirk whereby polymorphing into a form with
> different speed gives you one move movement at your old speed?
> (Polymorphing into a sessile monster gives you one last move.)

Not at all related.  That movement bug affected 3.6.0 but was fixed in
3.6.1.

6 years agofix #7470 - Sting vs webs
PatR [Fri, 26 Oct 2018 22:09:48 +0000 (15:09 -0700)]
fix #7470 - Sting vs webs

When trapped in a web, trying to move while wielding Sting gives the
message "Sting cuts through the web."  In 3.6.1 and earler, that
also released you from the trap, but with 3.6.2-beta nothing happens.

It had nothing to do with the recent web spinning patch.  My change
to have being trapped block levitating and flying included replacing
a lot of direct manipulations of u.utrap with set_utrap() and
reset_utrap() in order to keep the lev/fly blocking and unblocking
localized.  Unfortunately, the old 'u.utrap = 0' when wielding Sting
while stuck in web was deleted in error at that time.

6 years agostinking cloud vs drawbridge
PatR [Thu, 25 Oct 2018 21:15:55 +0000 (14:15 -0700)]
stinking cloud vs drawbridge

While looking at something else, I noticed that newsym() was checking
for pool and lava by examining the terrain type directly rather than
using the pool and lava checks, so it would never show a gas cloud at
a closed drawbridge (the spot in front of the portcullis).  Level's
terrain at a closed drawbridge spot is DRAWBRIDGE_UP; need to look at
drawbridgemask field to figure out whether the accessible terrain at
that spot is moat or lava.

6 years agoX11: Don't hilite the help ext menu entry
Pasi Kallinen [Thu, 25 Oct 2018 12:58:19 +0000 (15:58 +0300)]
X11: Don't hilite the help ext menu entry

Both the "help" button at top and the "help" extended menu command
were hilighted by the X resources. Make the top buttons have
"btn_" prefix, so they're easily distinguished in the resources.

6 years agoX11: Make TTY status obey hilite_status
Pasi Kallinen [Wed, 24 Oct 2018 17:04:28 +0000 (20:04 +0300)]
X11: Make TTY status obey hilite_status

6 years agoX11: Move color and font structs
Pasi Kallinen [Tue, 23 Oct 2018 17:30:44 +0000 (20:30 +0300)]
X11: Move color and font structs

... so that other window types can also use them.

6 years agoX11: Adjust some colors to differentiate them
Pasi Kallinen [Tue, 23 Oct 2018 14:48:54 +0000 (17:48 +0300)]
X11: Adjust some colors to differentiate them

6 years agoX11 status display
PatR [Mon, 22 Oct 2018 22:28:19 +0000 (15:28 -0700)]
X11 status display

Flag some unused parameters and remove some unused variables.
Fix compile for !defined(TEXTCOLOR).

6 years agoX11: TTY-style status lines
Pasi Kallinen [Mon, 22 Oct 2018 18:23:12 +0000 (21:23 +0300)]
X11: TTY-style status lines

Set X resource NetHack*fancy_status: False to enable the TTY-style
status lines. Default is the fancy status.

This patch is somewhat unfinished - even though the TTY-style status
allow for status hilites, the colors don't work correctly yet.
Also changes the fancy status to use the windowport notification code.

6 years agoX11: Mouse wheel scrolling for message window
Pasi Kallinen [Sun, 21 Oct 2018 16:30:05 +0000 (19:30 +0300)]
X11: Mouse wheel scrolling for message window

6 years agoX11: save and load message history
Pasi Kallinen [Sun, 21 Oct 2018 14:26:24 +0000 (17:26 +0300)]
X11: save and load message history

6 years agoRemove "makedefs -m" and monstr.c from the Unix build.
keni [Fri, 19 Oct 2018 16:54:33 +0000 (12:54 -0400)]
Remove "makedefs -m" and monstr.c from the Unix build.

6 years agotwo more windows supporting bits
nhmall [Wed, 17 Oct 2018 23:53:06 +0000 (19:53 -0400)]
two more windows supporting bits

6 years agowindows build mods to support branch change
nhmall [Wed, 17 Oct 2018 23:30:31 +0000 (19:30 -0400)]
windows build mods to support branch change
 Changes to be committed:
modified:   sys/winnt/Makefile.gcc
modified:   sys/winnt/Makefile.msc
modified:   win/win32/vs2015/NetHack.vcxproj
modified:   win/win32/vs2015/NetHackW.vcxproj
modified:   win/win32/vs2015/files.props
modified:   win/win32/vs2017/NetHack.vcxproj
modified:   win/win32/vs2017/NetHackW.vcxproj
modified:   win/win32/vs2017/files.props

6 years agoDeprecate "makedefs -m".
keni [Wed, 17 Oct 2018 19:37:24 +0000 (15:37 -0400)]
Deprecate "makedefs -m".
mons[].difficulty takes over for monstr[]
Invoking "makedefs -m" gives a deprecation message; it is also included
in the (now mostly empty) monstr.c.
Ports should now remove "makedefs -m" from their build procedures but this
commit does not include that change.

6 years agoGuidebook.mn #extended commands
PatR [Sat, 20 Oct 2018 21:56:50 +0000 (14:56 -0700)]
Guidebook.mn #extended commands

Change the extended command section from a mixture of
|#cmd This is a short-named command.
|#command
|     This is a long-named command.
to every command having its descriptive text start on the next line
|#cmd
|     This is a short-named command.
|#command
|     This is a long-named command.
which results in a longer document but the extended commands section
is much easier to read.

No change to Guidebook.txt, where the previous command name padding
was wide enough to accomplish the same for fixed-width tty font.
There is an update to that though; a previous change omitted it.

6 years agoWINCHAIN cleanup
PatR [Sat, 20 Oct 2018 09:23:45 +0000 (02:23 -0700)]
WINCHAIN cleanup

This started out as some formatting cleanup for src/windows.c but
ended up removing calloc() from the WINCHAIN code, plus fixing a
couple of compiler complaints for win/chain/wc_trace.c.

I tried to actually run with +trace enabled and never managed to
get anything to happen.  trace_procs_init() was never called.  I've
never tried to use it before so don't know whether something which
used to work has gotten broken or I'm just doing it wrong.

6 years agoX11: Fix couple issues from recent changes
Pasi Kallinen [Sat, 20 Oct 2018 08:17:35 +0000 (11:17 +0300)]
X11: Fix couple issues from recent changes

Segfault due to arg array overflow, and a theoretical fix for
a hang on a Mac during player selection if -@ parameter was given
on the command line.

6 years agounitm.c formatting
PatR [Sat, 20 Oct 2018 07:43:16 +0000 (00:43 -0700)]
unitm.c formatting

Some inconsequential stuff I've extracted out of a patch I've stalled
out on.

6 years agoFiles merge cleanup
nhmall [Fri, 19 Oct 2018 22:13:26 +0000 (18:13 -0400)]
Files merge cleanup

6 years agofix numerical ordering in Files
keni [Fri, 19 Oct 2018 14:45:32 +0000 (10:45 -0400)]
fix numerical ordering in Files

6 years agowishing bit
PatR [Fri, 19 Oct 2018 08:47:29 +0000 (01:47 -0700)]
wishing bit

Allow wishing for "cookie" or "pie" to succeed since we have items
those can match.

Unrelated:  allow ^G of "genie" for similar reason.

6 years agoUpdate Files. Add missing files and missing .lev section.
keni [Sat, 29 Sep 2018 20:43:39 +0000 (16:43 -0400)]
Update Files.  Add missing files and missing .lev section.

6 years agoRevert "fix github issue #94 - files missing from Files"
nhmall [Fri, 19 Oct 2018 01:43:36 +0000 (21:43 -0400)]
Revert "fix github issue #94 - files missing from Files"

This reverts commit ec19b52d8d760c89e70112bc0b61587054df1f64.

6 years agofix github issue #94 - files missing from Files
PatR [Fri, 19 Oct 2018 00:54:30 +0000 (17:54 -0700)]
fix github issue #94 - files missing from Files

Fixes #94

I thought maintenance of this was going to be automated?
Add missing special levels:  bigroom6..10.lev and medusa3..4.lev
in the generated at build time section of dat/.

6 years agofix github issue #38 - indentation vs `if {}'
PatR [Fri, 19 Oct 2018 00:15:42 +0000 (17:15 -0700)]
fix github issue #38 - indentation vs `if {}'

Fixes #38

In 3.6.1, some code in mfind0(detect.c) was mis-indented in a way
which suggested that the grouping within braces might not be what was
intended, and that was right--there was a pair of braces missing when
compared with older versions of the code involved.  A previous patch
(post-#38) had changed the indentation to match the surrounding braces
without really addressing the issue.  But it turned out not to make
any difference either way since mundetected is only used by hiders
and eels.  This reorganizes the relevant code to make it simpler to
understand, I hope.

6 years agoGuidebook.tex quoting
PatR [Thu, 18 Oct 2018 21:37:41 +0000 (14:37 -0700)]
Guidebook.tex quoting

Change instances of 'C' and ``C'' to `C'.
Change a few double quotes, "..." to ``...''.
Remove some trailing spaces (for Guidebook.mn too).

One tweak in wording:  for #offer, ``use `m' to skip items on altar''
followed by ``you'll need to find an altar'' sounded strange.  Move the
``skip items on altar'' sentence after the ``need an altar'' sentence.

6 years agoX11 compile bit
PatR [Thu, 18 Oct 2018 19:57:07 +0000 (12:57 -0700)]
X11 compile bit

6 years agoX11: Add key and mouse scrolling to extended command menu
Pasi Kallinen [Thu, 18 Oct 2018 18:33:17 +0000 (21:33 +0300)]
X11: Add key and mouse scrolling to extended command menu

6 years agoX11: Handle the -@ parameter
Pasi Kallinen [Thu, 18 Oct 2018 16:29:42 +0000 (19:29 +0300)]
X11: Handle the -@ parameter

6 years agoX11: Obey menu movement keys
Pasi Kallinen [Thu, 18 Oct 2018 15:39:27 +0000 (18:39 +0300)]
X11: Obey menu movement keys

6 years agoX11: Revert finding scrollbars in same window
Pasi Kallinen [Thu, 18 Oct 2018 14:19:26 +0000 (17:19 +0300)]
X11: Revert finding scrollbars in same window

Apparently this doesn't work, for some reason every widget reports
a different window, even when they are in the same window ...
Maybe widgets inside and outside a viewport are technically
in different windows?

6 years agoX11 winmenu.c housekeeping
PatR [Wed, 17 Oct 2018 21:43:44 +0000 (14:43 -0700)]
X11 winmenu.c housekeeping

Fix a couple of compiler complaints, and move some new local functions
out of the region of the file labeled `global functions'.

6 years agoGuidebook.txt update
PatR [Wed, 17 Oct 2018 12:25:51 +0000 (05:25 -0700)]
Guidebook.txt update

6 years agoGuidebook.mn single quotes
PatR [Wed, 17 Oct 2018 12:22:36 +0000 (05:22 -0700)]
Guidebook.mn single quotes

Replace `C' and 'C' with \(oqC\(cq (open and close single quote).
For plain text output, the new form generates the first form.  Most
single quotes were using that, but there was quite a bit of C-style
char quoting that was somewhat inconsisent.

There are several text changes too, mostly small.  The few I can
remember are
  replacing several ``#twoweapon'' with `X';
  pets:  change 'cat' to 'kitten' and mention that horses are
    vegetartian where it claims that pets usually feed themselves;
  NETHACKOPTIONS:  add `bash' to the shells mentioned,
    describe `NETHACKOPTIONS=@filename' better,
    shorten the example (it's still too long for Guidebook.txt);
  Configuring Status Hilites:  expand the `behavior' descriptions
    to mention the value limits for percentage and absolute, and
    include post-3.6.1 '<=' and '>=' for them,
    add omitted fields `hunger' and `title' to text match.

I also changed a bunch of examples in the option configuation section
from bold font to constant-width Roman which more closely resembles
the \tt font in TeX.  Probably a whole bunch of other bold items
ought to follow suit.

Issues:
  title for section 9.3 (NETHACKOPTIONS) is too close to the sample
    config file at the end of section 9.2;
  as mentioned above, the sample ``setenv NETHACKOPTIONS foo'' is
    much too long for Guidebook.txt, and ``NETHACKOPTIONS=foo'' is
    slightly too long; they're ok in Guidebook.ps (assuming default
    page size);
  does `WIZKIT=~/wizkit.txt' actually work?  That's the example shown.

6 years agoa few Guidebook tweaks
PatR [Tue, 16 Oct 2018 22:18:09 +0000 (15:18 -0700)]
a few Guidebook tweaks

I started out updating Guidebook.mn to use \(oq and \(cq for single
quotes but ended up including some new text.  I've separated that
part out (there are a few instances of altered quoting in the midst
of it--the separation wasn't 100%) to commit separately.

Add verbiage to "choosing race" and several commands:  f, s, S, t,
w, and ^X.

Change `E-' and `w-' to use minus sign instead of hyphen.  The TeX
edition uses \tt font for those which has the same effect of making
those dashes be more prominent.

Fix typo/thinko in `IX':  Guidebook.mn and Guidebook.txt said that
displayed inventory items whose bless/curse state is "known".
Guidebook.tex had it right, "unknown".

6 years agoX11: Find scrollbars in same window
Pasi Kallinen [Tue, 16 Oct 2018 17:44:52 +0000 (20:44 +0300)]
X11: Find scrollbars in same window

Adding scroll() translations to a window with no scrollbars
scrolled the main window message area.

6 years agoX11: Add geometry handler on perm_invent win only
Pasi Kallinen [Tue, 16 Oct 2018 16:21:46 +0000 (19:21 +0300)]
X11: Add geometry handler on perm_invent win only

6 years agoX11: Remember perm_invent window geometry
Pasi Kallinen [Tue, 16 Oct 2018 16:08:45 +0000 (19:08 +0300)]
X11: Remember perm_invent window geometry

Instead of remembering the geometry at window closing time,
remember it immediately when it changes.

6 years agoX11: Allow toggling mouse_support off
Pasi Kallinen [Tue, 16 Oct 2018 15:09:50 +0000 (18:09 +0300)]
X11: Allow toggling mouse_support off

Prevents accidental mouse clicks on the map.

6 years agoX11: Don't reuse perm_invent window for picking an object
Pasi Kallinen [Tue, 16 Oct 2018 14:39:42 +0000 (17:39 +0300)]
X11: Don't reuse perm_invent window for picking an object

The core wants to reuse the permanent inventory window for choosing
an object from inventory, but the perm_invent window could be
hard to focus - it could even be on another display!

Instead, create a temporary new window from which the user can
pick an inventory item.

6 years agofix #H7453 - 'bonesknown' for dead hero
PatR [Tue, 16 Oct 2018 01:26:49 +0000 (18:26 -0700)]
fix #H7453 - 'bonesknown' for dead hero

Dead hero's map coordinates are set to <0,0> part way through bones
creation, then were being used to record grave location for overview
feedback with "final resting place for <dead hero>" if/when another
character got those bones and found the grave (actually, spotted the
location where first hero died regardless of whether a grave gets
placed there).  Record dead hero's pre-<0,0> coordinates as intended.

Not previously noticed because in wizard mode the final resting place
becomes part of overview info as soon as bones are loaded rather than
waiting for the death location to be reached.

6 years agoX11: Allocate menu translation tables only once
Pasi Kallinen [Mon, 15 Oct 2018 15:37:02 +0000 (18:37 +0300)]
X11: Allocate menu translation tables only once

Also force free the menu entry widgets when non-perm-invent
window is popped down.

6 years agorefresh Guidebook.txt again
PatR [Mon, 15 Oct 2018 00:49:27 +0000 (17:49 -0700)]
refresh Guidebook.txt again

Features the 'boxed' screenshot.  Unfortunately, pushing that to the
next page changes all the following pages, so diff is big.

6 years agoGuidebook.mn screenshot
PatR [Mon, 15 Oct 2018 00:46:48 +0000 (17:46 -0700)]
Guidebook.mn screenshot

Putting a box around the simulated screenshot has a side-effect of
forcing it to the next page if there isn't room on the current page.
And it looks at least as good as the old top and bottom horizontal
lines, if not better.  This also eliminates the blank left-most
column (relative to those lines) which isn't part of the screenshot.

There are issues:
1) for Guidebook.ps, the "Figure 1" label underneath seems to be
   too close to the box; I didn't try to force a blank line in front
   of it because that increases the risk of pushing it to the next
   page if the figure lands at the bottom;
2) for Guidebook.txt, the "Figure 1" label actually overwrites the
   bottom line of the box, and the embedded space allows the line
   to show through:  "---Figure-1---"; I tried using "\ Figure\ 1\ "
   to see if that might hide the issue by making it seem that the
   label in intended to be on that line, but it didn't help--
   unbreakable-space evidently does not imply always-visible-space;
3) the box is one column wider than the rest of the document (the
   previous horizontal lines were two or three columns wider, so
   this is actually a tiny imrovement); squeezing out some whitespace
   to make the status lines narrower didn't help--or at least not
   enough; squeezing some spaces was needed to match STATUS_HILITES-
   era status formatting anyway.
4] if there was a footnote (we have some for trademarks) on the same
   page as the screenshot, either the footnote or the table would
   probably become confused, perhaps both.  I think we just pretend
   that that will never come up....
5} I've made no attempt to alter Guidebook.tex to try to match.

I'm throwing in the towel.  Fixing this up is way beyond my limited
'roff/tbl capability.  (There's probably a much more straightforward
way to achieve what we want.)

6 years agobring Guidebook.txt up to date
PatR [Sun, 14 Oct 2018 22:09:40 +0000 (15:09 -0700)]
bring Guidebook.txt up to date

I may not get around to doing anything with 'C' vs `C' vs \(oqC\(cq
for a while.  Bring Guidebook.txt up to date now rather than waiting
so that the repository's copy reflects the #H7444 fix.

This has ended up with substantial spurious differences due to it
placing padding in different spots during line justification.  I
hope that's due to different groff version using a slightly different
algorithm rather than something like phase of the moon.  :-]
There also differences caused by "..." taking less space than ``...''.

6 years agofix #H7444 - bad line split in Guidebook
PatR [Sun, 14 Oct 2018 21:30:02 +0000 (14:30 -0700)]
fix #H7444 - bad line split in Guidebook

Reported for Windows beta3 but turns out to be present in 3.6.1
distribution.
| #wait
|      Rest one move while doing nothing. Default key is '.', and '
|      ' if rest_on_space is on.
where the line split occurs in the middle of "' '".  We should
switch from the ascii single quote to the 'nroff open and close
single quote escapes but I haven't gotten around to that.
Preceding the space with backslash prevents a line break there.

6 years agoGuidebook.mn update
PatR [Sun, 14 Oct 2018 19:58:59 +0000 (12:58 -0700)]
Guidebook.mn update

Replace ``foo'' with \(lqfoo\(rq (many instances) so that the
plain text Guidebook will use ".  Also a few `bar' with \(lqbar\(rq
(mostly `#enhance' and `#twoweapon') to be consistent with other
command names that all use double quotes.  And replace a few strings
in actual double quotes with corresponding \(lq or \(rq.

Replace command descriptions using ^X with \(haX to get the larger
circumflex character (aka 'hat') instead of the smaller circumflex
punctuation.  (Not noticeable with plain text output.)

Changed one DOS and a few MSDOS to MS-DOS to match the spelling in
the trademark line at the end.

Start each sentence on its own line for the paragraphs which were
being subjected to the above changes.

Also a much smaller subset for Guidebook.tex (not tested...).

Does not address the "wrapped to next line in middle of ' '" issue.

6 years agofix github pull request #144 - uswapwep vs shield
PatR [Sun, 14 Oct 2018 09:47:09 +0000 (02:47 -0700)]
fix github pull request #144 - uswapwep vs shield

Fixes #144

While giving a new character his/her starting equipment, don't clear
alternate weapon when putting on a shield since that weapon should
still be available to swap with primary.  Affected knight's lance
and valkyrie's dagger.

Also, guard against wearing an initial shield if already wielding a
two-handed weapon, or wielding such a weapon if already wearing a
shield.  Both situations are hypothetical with current starting gear.

6 years agofix #H7446 and #H7448 - Guidebook bits
PatR [Sun, 14 Oct 2018 09:02:41 +0000 (02:02 -0700)]
fix #H7446 and #H7448 - Guidebook bits

\#H7448 - option 'dark_room' showed incorrect default value.

\#H7446 - persistence of objects section was missing a word in
its second paragraph.

Also, fix up some clumsy wording in the first paragraph of that
same section.

6 years agoElbereth tweaks
PatR [Sun, 14 Oct 2018 01:14:34 +0000 (18:14 -0700)]
Elbereth tweaks

Don't "feel like a hypocrite" when on Elberth and attacking a monster
which isn't scared by Elbereth (exception:  peaceful creatures aren't
scared but attacking them in such situation is hypocritical anyway).
This means that players can use Elbereth to scare away some creatures
while continuing to fight others.  Elbereth won't be automatically
erased, but weapon attacks will scuff the engraving; wand zaps don't.

Reduce the -5 alignment penalty when alignment is 5 or less.  Reduced
amount is -(1..5), so -3 average.

6 years agoX11: Handle X errors via panic
Pasi Kallinen [Sat, 13 Oct 2018 12:07:23 +0000 (15:07 +0300)]
X11: Handle X errors via panic

This leaves a usable backtrace for debugging.

6 years agoX11 build fix
PatR [Sat, 13 Oct 2018 01:10:06 +0000 (18:10 -0700)]
X11 build fix

Replace a C99ism.

6 years agokeyhelp missed during Windows build steps
nhmall [Sat, 13 Oct 2018 00:57:26 +0000 (20:57 -0400)]
keyhelp missed during Windows build steps

BUG REPORT:

    comments:
    1. I start a new character.
    2. The first command I type is '&'
    3. I type "?" and "<enter key>" at the prompt.
    4. Cannot open "keyhelp" data file!--More--
       ?    give a help message.

1559

6 years agoFix segfault in X11 perm_invent if it was partially obscured
Pasi Kallinen [Fri, 12 Oct 2018 21:37:15 +0000 (00:37 +0300)]
Fix segfault in X11 perm_invent if it was partially obscured

6 years agoX11: Allow bold attribute for menucolors
Pasi Kallinen [Fri, 12 Oct 2018 17:46:19 +0000 (20:46 +0300)]
X11: Allow bold attribute for menucolors

6 years agoX11: Remember perm_invent window geometry
Pasi Kallinen [Thu, 11 Oct 2018 17:18:04 +0000 (20:18 +0300)]
X11: Remember perm_invent window geometry

6 years agoX11: Handle paged menu control keys
Pasi Kallinen [Thu, 11 Oct 2018 15:05:56 +0000 (18:05 +0300)]
X11: Handle paged menu control keys

X11 doesn't do menu paging, so handle the select page, invert page,
and unselect page like selecting, inverting or unselecting all.

6 years agoX11: Mouse wheel scrolling in menus
Pasi Kallinen [Thu, 11 Oct 2018 14:59:20 +0000 (17:59 +0300)]
X11: Mouse wheel scrolling in menus

6 years agoX11 menus
PatR [Thu, 11 Oct 2018 00:04:11 +0000 (17:04 -0700)]
X11 menus

Fix some compiler warnings and some formatting.

Builds cleanly but is otherwise untested.

6 years agoX11: Menucolors
Pasi Kallinen [Wed, 3 Oct 2018 14:08:02 +0000 (17:08 +0300)]
X11: Menucolors

Replace the XawList with our own lists of labels and command widgets
to allow for menucolors. Supports only inverse line attribute for now.

Allow key translations to work with menus on Linux.

6 years agoFix Qt compilation
Patric Mueller [Wed, 10 Oct 2018 01:08:15 +0000 (03:08 +0200)]
Fix Qt compilation

6 years agoensure tmp_at() structures are initialized for all code paths when swallowed
nhmall [Fri, 5 Oct 2018 02:02:28 +0000 (22:02 -0400)]
ensure tmp_at() structures are initialized for all code paths when swallowed

6 years agoRevert "ensure tmp_at() structures are initialized for all code paths when swallowed"
nhmall [Fri, 5 Oct 2018 02:00:51 +0000 (22:00 -0400)]
Revert "ensure tmp_at() structures are initialized for all code paths when swallowed"

This reverts commit 39074d29fc157c8eb02c17417a449819d91c7a0b.

Bad commit of do_throw

6 years agoRevert "fix up a bad commit"
nhmall [Fri, 5 Oct 2018 02:00:08 +0000 (22:00 -0400)]
Revert "fix up a bad commit"

This reverts commit 2eb8436db2b8a7123857f386a89003aed18c71d4.

6 years agofix up a bad commit
nhmall [Fri, 5 Oct 2018 01:55:01 +0000 (21:55 -0400)]
fix up a bad commit

6 years agoensure tmp_at() structures are initialized for all code paths when swallowed
nhmall [Fri, 5 Oct 2018 01:49:16 +0000 (21:49 -0400)]
ensure tmp_at() structures are initialized for all code paths when swallowed

6 years agoformatting cleanup src/*.c
PatR [Tue, 2 Oct 2018 23:53:22 +0000 (16:53 -0700)]
formatting cleanup src/*.c

Remove trailing spaces, and remove tabs from the files that had
trailing spaces.

Also, rndorcname() was using a random value to terminate a loop
and was recalculating a new one each iteration.

6 years agochange default for 'autodescribe' to 'on'
PatR [Mon, 1 Oct 2018 22:08:33 +0000 (15:08 -0700)]
change default for 'autodescribe' to 'on'

This was discussed two years ago then nothing happened.  Make
autodescribe for feedback when moving the cursor to pick something
default to on instead of off.

6 years agountrap downwards while over trap
PatR [Sun, 30 Sep 2018 23:37:32 +0000 (16:37 -0700)]
untrap downwards while over trap

Force trap to activate during failed untrap attempt if done while
already at the trap's location, to match the recent change in
behavior when failed attempt occurs while adjacent to the trap.

Most noticeable while flying over bear traps, but affects all
failed untrap attempts.

6 years agoa couple of steed Flying messages
nhmall [Sun, 30 Sep 2018 14:01:43 +0000 (10:01 -0400)]
a couple of steed Flying messages

6 years agocomment typo in music.c
nhmall [Sun, 30 Sep 2018 12:45:49 +0000 (08:45 -0400)]
comment typo in music.c

6 years agotile.c formatting
PatR [Sun, 30 Sep 2018 09:11:32 +0000 (02:11 -0700)]
tile.c formatting

Modify win/share/tilemap.c so that generated source file src/tile.c
uses similar formatting to the other sources.  Mainly, avoid tabs and
use 4 columns indentation instead of 8 columns in the short routine
near the end.

tilemap.c still treats STATUES_LOOK_LIKE_MONSTERS as conditional.
The main sources made that unconditional prior to release of 3.6.0.

6 years agofix #H6925 - being trapped vs Levitation/Flying
PatR [Sun, 30 Sep 2018 08:06:59 +0000 (01:06 -0700)]
fix #H6925 - being trapped vs Levitation/Flying

Make being trapped in/on/over floor block Levitation and Flying, the
way that being inside solid rock already does, and the way levitating
blocks flight.

Blocked levitation still provides enhanced carrying capacity since
magic is attempting to make the hero's body be bouyant.  I think that
that is appropriate but am not completely convinced.

One thing that almost certainly needs fixing is digging a hole when
trapped in the floor or tethered to a buried iron ball, where the
first part of digactualhole() releases the hero from being trapped.
If being released re-enables blocked levitation, the further stages
of digging might not make sense in some circumstances.

I recently realized that being held by a grabbing monster is similar
to being trapped so should also interfere with levitation and flying.
Nothing here attempts to address that.

Save files change, but in a compatible fashion unless trapped at the
time of saving.  If someone saves while trapped prior to this patch,
then applies it and restores, the game will behave as if the patch
wasn't in place--until escape from trap is achieved.  (Not verified.)

6 years agomove assignment outside inner loop
nhmall [Sun, 30 Sep 2018 03:38:20 +0000 (23:38 -0400)]
move assignment outside inner loop

6 years agoone more update for the right of the status line
nhmall [Sun, 30 Sep 2018 03:21:11 +0000 (23:21 -0400)]
one more update for the right of the status line

This tracks the last character written on each row and clears
the previous content from the end independently of which field
is actually involved.

6 years agorevisit display artifact appearing to the right of status line
nhmall [Sun, 30 Sep 2018 02:28:10 +0000 (22:28 -0400)]
revisit display artifact appearing to the right of status line

The prior fix for this was a bit flawed. It was only considering
the length of the last field, but what it really needed to do was
consider the placement of the last character of the last field
on the row relative to the placement of the last character of
the last field on the row previously.

If the new placement of that last character of the last field
is left of the previous placement, some clearing must be done.

6 years agodisplay cleanup only targets the right-most field where it's needed
nhmall [Fri, 28 Sep 2018 16:55:30 +0000 (12:55 -0400)]
display cleanup only targets the right-most field where it's needed

6 years agofollow-up bit
nhmall [Fri, 28 Sep 2018 06:28:54 +0000 (02:28 -0400)]
follow-up bit

6 years agoMerge branch 'NetHack-3.6.2-beta01' of https://rodney.nethack.org:20040/git/NHsource...
nhmall [Fri, 28 Sep 2018 06:09:30 +0000 (02:09 -0400)]
Merge branch 'NetHack-3.6.2-beta01' of https://rodney.nethack.org:20040/git/NHsource into NetHack-3.6.2-beta01

6 years agotty: fix leftover display artifact when last field on the row got smaller
nhmall [Fri, 28 Sep 2018 06:09:07 +0000 (02:09 -0400)]
tty: fix leftover display artifact when last field on the row got smaller

6 years agoalternate bear trap fix
PatR [Fri, 28 Sep 2018 01:42:12 +0000 (18:42 -0700)]
alternate bear trap fix

Fix the situation of Flying hero failing to untrap a bear trap that
was resulting in the trap becoming hidden.  Previous fix prevented
hero from moving onto the trap's location so that the reason for
hiding it didn't occur.  This moves the hero and forces the trap,
so it will become unhidden again before there's any chance to notice
that it had been hidden.

Status 'Flying' conflicts with being trapped at floor level, but that
is a separate, known issue.  I'll have to resurrect my unfinished fix
for that sooner rather than later.

6 years agofix typo of the Junethack tournament
Patric Mueller [Thu, 27 Sep 2018 20:13:58 +0000 (22:13 +0200)]
fix typo of the Junethack tournament

6 years agomore extended command help
PatR [Thu, 27 Sep 2018 10:52:23 +0000 (03:52 -0700)]
more extended command help

For the searching capability offered by '# ?', use ':' instead of 's'
to activate it.  Otherwise, if the player typed ':', menu processing
would handle that and would search the few menu entries (for selectors
'a', 's'--now ':', and maybe 'z') when we're interested in searching
the data displayed via many separator lines.

I left 's' as the selector for "show all, clear search" once a search
has been performed, but perhaps that ought to be switched to ':' too.

6 years agomonpolycontrol, wizdebug_*
PatR [Thu, 27 Sep 2018 01:40:13 +0000 (18:40 -0700)]
monpolycontrol, wizdebug_*

Demote #monpolycontrol and #wizdebug_traveldisplay from commands to
simple boolean options.  The former has the same name, the latter
is called travel_debug.  Rename #wizdebug_bury to #wizbury; it
shouldn't matter that it goes away when compiled without DEBUG.

There are now five wizard-mode boolean options:  monpolycontrol,
sanity_check, and wizweight are documented in the Guidebook;
menu_tab_sep and travel_debug are commented out there.

Guidebook.mn has been tested; Guidebook.tex has not.

6 years agofix out of bounds error in tty_status_update() for BL_HUNGER case
nhmall [Wed, 26 Sep 2018 21:18:09 +0000 (17:18 -0400)]
fix out of bounds error in tty_status_update() for BL_HUNGER case

The pointer could go out of bounds when decremented if it was pointing
at the start of the status_vals[BL_HUNGER] (empty string).

Also, guard tty_status_update() from an out of range index being
passed to it (botl shouldn't do that, but...).

The legal 1st parameter values for tty_status_update() in 3.6.2 are

BL_RESET     (-2)
BL_FLUSH     (-1)
BL_TITLE     ( 0)
...though to...
BL_CONDITION (22)

  count MAXBLSTATS = (BL_CONDITION + 1)

There's a BL_CHARACTERISTIC (-3) defined in the botl.h header file,
but it is not used in wintty.c and is now screened out along with
everything lower and everything MAXBLSTATS and above.

closes #142
fixes #141

6 years agoengr follow-up bit
nhmall [Wed, 26 Sep 2018 05:35:48 +0000 (01:35 -0400)]
engr follow-up bit

6 years agowand of polymorph engrave for blind writers
nhmall [Wed, 26 Sep 2018 05:10:27 +0000 (01:10 -0400)]
wand of polymorph engrave for blind writers

Don't provide any discerning feedback on the blind player's turn
but do allow the wand to exercise its magic in a manner reflective
of blind writers

6 years agofix missing space in "would flyif you weren't levitating"
nhmall [Wed, 26 Sep 2018 03:28:20 +0000 (23:28 -0400)]
fix missing space in "would flyif you weren't levitating"

Fixes #140

6 years agoMerge branch 'copperwater-flyif_fix' into NetHack-3.6.2-beta01
nhmall [Wed, 26 Sep 2018 03:24:44 +0000 (23:24 -0400)]
Merge branch 'copperwater-flyif_fix' into NetHack-3.6.2-beta01

6 years agoMerge branch 'flyif_fix' of https://github.com/copperwater/NetHack into copperwater...
nhmall [Wed, 26 Sep 2018 03:22:11 +0000 (23:22 -0400)]
Merge branch 'flyif_fix' of https://github.com/copperwater/NetHack into copperwater-flyif_fix

6 years agoFix "would flyif you weren't levitating" - missing space
copperwater [Wed, 26 Sep 2018 03:14:45 +0000 (23:14 -0400)]
Fix "would flyif you weren't levitating" - missing space

6 years agodon't impact player stats with wizard mode ^T
nhmall [Wed, 26 Sep 2018 03:08:09 +0000 (23:08 -0400)]
don't impact player stats with wizard mode ^T

6 years agofix #7414 - bug with Japanese names for Samurai
PatR [Wed, 26 Sep 2018 01:01:44 +0000 (18:01 -0700)]
fix #7414 - bug with Japanese names for Samurai

Description for use when an item hasn't been seen up close yet falls
back to real name if there is no separate description, but was doing
so before real name substitution for samurai.
 actualn = foo;
 dn = description ? description : actualn;
 if (Samurai)
  actualn = bar;
So player saw a flail (via 'dn') until dknown bit got set, then
nunchaku (via 'actualn' after it got set to samurai-specific value).

Wait until after substitution of Japanese real names before falling
back to real name when there's no description.