Z+Angband dev

Collapse
X
 
  • Time
  • Show
Clear All
new posts
  • Pete Mack
    Prophet
    • Apr 2007
    • 6697

    #31
    Hmmm. One reason I like the current model is that every class of game data now has an iterator associated; that is, it forrms a normalized relation. I come from databases as much as programming, and this just seems natural to me. Take a look at the lore code to see why this can help.

    Comment

    • Gwarl
      Administrator
      • Jan 2017
      • 986

      #32
      Hi t4nk check out the progress I made on angband.live, I think it's taken a different direction since we spoke about it and I don't expect work from you but it is nice to see you came back to angband after all.

      Comment

      • t4nk
        Swordsman
        • May 2016
        • 335

        #33
        Originally posted by Gwarl
        Hi t4nk check out the progress I made on angband.live, I think it's taken a different direction since we spoke about it and I don't expect work from you but it is nice to see you came back to angband after all.
        That looks pretty fancy. I see you've even forked Poschengband? Congratulations

        Comment

        • droof
          Apprentice
          • Dec 2013
          • 71

          #34
          I've looked around in Z variants. Poschengband completely replaces Zangband 2.4, just everything is better in Poschengband. It's the "static quest" Z branch.

          Zangband 2.7.5 is a different beast though and Z+Angband has continued development on that version. This looks like the branch with the promise for a true random wilderness and dynamic interesting quests. So it makes sense to continue development on Z+Angband.

          Zangband and Z+Angband only have sound support for Amiga and Mac Carbon. Oh Amiga, good memories there. Sound and music don't work, this needs SDL mixer code for modern sound support.

          ZangbandTK is interesting in that it has all game commands and options in window menus. I haven't seen that in any other variant yet. That's very useful for feature discoverability.

          Comment

          • johnretroreload
            Rookie
            • Feb 2018
            • 20

            #35
            I'm really enjoying the discussion of the code and potential directions of a new Z+Angband project.
            2.7.5 was the definitive return to the soul of zang for me which Z+angband has continued. Quests and randomisation remain key for me on this variant.
            That will explain why I was having trouble with the Win and Dos build in enabling the sound+music, thanks for highlighting.
            Lua in newest TOME - I haven't considered that.. Nice comment by droof about migrating and syncing for a v3.5 for easier future coding concept.
            Fun and fresh while being authentic to vanilla zang is key for me.




            Originally posted by droof
            I've looked around in Z variants. Poschengband completely replaces Zangband 2.4, just everything is better in Poschengband. It's the "static quest" Z branch.

            Zangband 2.7.5 is a different beast though and Z+Angband has continued development on that version. This looks like the branch with the promise for a true random wilderness and dynamic interesting quests. So it makes sense to continue development on Z+Angband.

            Zangband and Z+Angband only have sound support for Amiga and Mac Carbon. Oh Amiga, good memories there. Sound and music don't work, this needs SDL mixer code for modern sound support.

            ZangbandTK is interesting in that it has all game commands and options in window menus. I haven't seen that in any other variant yet. That's very useful for feature discoverability.

            Comment

            • Pete Mack
              Prophet
              • Apr 2007
              • 6697

              #36
              Lua is overrated, IMO. Yeah it allows flexibility in spell set, but 8t turns out that the flexibility is almost never needed. When a spell can be described by a line or two in a text file, and there are a h7ndred or more spells, adding even a small amount of boilerplate multiplies fast. Text file+simple parser really is considered a software best practice. It's right there in all the textbooks.

              Comment

              • droof
                Apprentice
                • Dec 2013
                • 71

                #37
                Lua is used by game engines. Scripted story sequences, scripted levels, complex quests, new game modules, total conversions and in case of Doom 3 I think it was even used for artificial intelligence monster behaviour.

                But Angband is a game, not a game engine. It's not like anyone could write a total conversion mod in Lua for Angband, instead that gets hacked into the code in C.

                If Angband was really a game engine and Vanilla Angband was a Lua module for the game, then that would a different story. That would be like the T-Engine.

                Comment

                • Pete Mack
                  Prophet
                  • Apr 2007
                  • 6697

                  #38
                  OK, that makes sense. The way angband 3.0 used it really didnt.

                  Comment

                  • johnretroreload
                    Rookie
                    • Feb 2018
                    • 20

                    #39
                    Originally posted by droof
                    Lua is used by game engines. Scripted story sequences, scripted levels, complex quests, new game modules, total conversions and in case of Doom 3 I think it was even used for artificial intelligence monster behaviour.

                    But Angband is a game, not a game engine. It's not like anyone could write a total conversion mod in Lua for Angband, instead that gets hacked into the code in C.

                    If Angband was really a game engine and Vanilla Angband was a Lua module for the game, then that would a different story. That would be like the T-Engine.
                    Coding as clean and efficiently as possible, thanks for clarifying. I'm weak on programming these days.

                    Comment

                    • AnonymousHero
                      Veteran
                      • Jun 2007
                      • 1322

                      #40
                      Originally posted by droof
                      Lua is used by game engines. Scripted story sequences, scripted levels, complex quests, new game modules, total conversions and in case of Doom 3 I think it was even used for artificial intelligence monster behaviour.
                      Just shows that people don't learn from their mistakes As a practical matter, yes, it has been used successfully... but the so has Visual Basic.

                      Originally posted by droof
                      But Angband is a game, not a game engine. It's not like anyone could write a total conversion mod in Lua for Angband, instead that gets hacked into the code in C.
                      This is an excellent and apt point. I have an aversion towards Lua because my first encounter with it was while porting T2 away from Lua into C/C++[1]. I don't think the science is anywhere near settled on dynamic/static typing in terms of defect rates, but Lua just seems to make all the wrong decisions even for a dynamically typed language: Arrays are really just magical hashes, indexing the wrong thing doesn't say "hey! you indexed the wrong thing", it just returns "nil", there doesn't seem to be any data structure other than hashes, really, etc. It just awful... and my hypothesis is that the only way the big studios have been able to make it work is because they can throw a lot of people/testing at it. (Of course, DarkGod isn't a big studio, but DarkGod is DarkGod.)

                      [1] ... and you're absoultely, right T2/Angband was not using Lua as a higher level scripting over a high-perf C engine. It was just "let's write C in Lua" (T2) or "let's use Lua to avoid doing a parser for dice-arithmetic" (Angband)... which is pointless and awful.

                      Comment

                      • Pete Mack
                        Prophet
                        • Apr 2007
                        • 6697

                        #41
                        Oh gods yes. The way it was done in 3.0 was WORSE than the initial and temporary hack of turning it into a giant case statement in V3.1. It just added a second language AND extra boilerplate. Parsing text files is so much cleaner all around. So is generating code with CPP where necessary.

                        Originally posted by AnonymousHero
                        "let's use Lua to avoid doing a parser for dice-arithmetic" (Angband)... which is pointless and awful.

                        Comment

                        • droof
                          Apprentice
                          • Dec 2013
                          • 71

                          #42
                          I think the C language is a barrier for new developers to try working on their ideas for a new variant. It was for me back in 2013. Maybe Lua isn't a good language either for creative feature coding, but there are plenty of alternatives. For example, Python is gaining popularity and is replacing Lua in some game engines and IoT platforms. Python is also used for education and serious work.

                          If we want variants that offer something unique and different from what we've seen before, then that requires coding and changes to core functionality. Text files only extend or theme what's already in place.

                          With text parsers maybe we can get new stories in D&D. With scripting, someone should be able to turn D&D into Pathfinder.

                          Comment

                          • Derakon
                            Prophet
                            • Dec 2009
                            • 8820

                            #43
                            Speaking as someone who tried to rewrite Angband in Python, more or less: it is a ton of work. Especially if you want to do a clean rewrite, rather than just re-implement C code in a different language.

                            Ultimately, it turned out that I don't care that much about Angband that I was willing to see the project through. I still feel bad for the people here that contributed to the project, only to see it die on the vine...

                            Comment

                            • Nick
                              Vanilla maintainer
                              • Apr 2007
                              • 9344

                              #44
                              Originally posted by droof
                              I think the C language is a barrier for new developers to try working on their ideas for a new variant. It was for me back in 2013.
                              Maybe so, but it's the language Angband is written in. As Derakon indicates, any project that starts off as a complete redo of many thousands of lines of code is so ambitious as to be almost certain to fall short.

                              A much easier route is to start by making small changes, getting more ambitious as you better understand the language and the codebase. If starting from current V, my ongoing efforts to move stuff from C code out to the text datafiles should help with that.

                              Note that I'm not suggesting no change for the sake of no change. It's just that I've been doing Angband coding for 12 years or so now - starting from pretty minimal knowledge of C. Feel free to ignore me though - learning from one's own mistakes is usually more effective
                              One for the Dark Lord on his dark throne
                              In the Land of Mordor where the Shadows lie.

                              Comment

                              • Pete Mack
                                Prophet
                                • Apr 2007
                                • 6697

                                #45
                                I don't think Python would make it a whole lot easier, except for the new object code, which was horribly plagued by stray pointer issues. A lot of complexity in Angband is language-independent.

                                Comment

                                Working...
                                😀
                                😂
                                🥰
                                😘
                                🤢
                                😎
                                😞
                                😡
                                👍
                                👎