[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 488: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 112: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 112: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 112: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 112: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 112: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 112: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 112: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 112: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 112: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 112: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 112: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 112: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/bbcode.php on line 112: preg_replace(): The /e modifier is no longer supported, use preg_replace_callback instead
[phpBB Debug] PHP Warning: in file [ROOT]/includes/functions.php on line 4787: Cannot modify header information - headers already sent by (output started at [ROOT]/includes/functions.php:3922)
[phpBB Debug] PHP Warning: in file [ROOT]/includes/functions.php on line 4789: Cannot modify header information - headers already sent by (output started at [ROOT]/includes/functions.php:3922)
[phpBB Debug] PHP Warning: in file [ROOT]/includes/functions.php on line 4790: Cannot modify header information - headers already sent by (output started at [ROOT]/includes/functions.php:3922)
[phpBB Debug] PHP Warning: in file [ROOT]/includes/functions.php on line 4791: Cannot modify header information - headers already sent by (output started at [ROOT]/includes/functions.php:3922)
InsideQC Forums • View topic - Quake Standards Base discussion

Quake Standards Base discussion

Discuss anything not covered by any of the other categories.

Moderator: InsideQC Admins

Postby r00k » Tue Mar 02, 2010 6:28 am

r00k
 
Posts: 1111
Joined: Sat Nov 13, 2004 10:39 pm

Postby goldenboy » Sun Mar 07, 2010 12:35 am

User avatar
goldenboy
 
Posts: 924
Joined: Fri Sep 05, 2008 11:04 pm
Location: Kiel

Postby goldenboy » Sun Mar 07, 2010 12:39 am

User avatar
goldenboy
 
Posts: 924
Joined: Fri Sep 05, 2008 11:04 pm
Location: Kiel

Postby goldenboy » Mon Jul 19, 2010 8:58 am

OK, who is interested in really getting together and defining a small set of core features that a QSB 1 should contain - following the 90/10 rule that Baker mentioned, 90 percent of the gain for 10 percent of the effort?

http://quakery.quakedev.com/qwiki/index.php/QSB

The list of map limits and extensions on the Quake Wiki page is still too big for a first attempt IMO. So let's try to pare it down:



RemakeQuake is a humungous mod, and we already break most of the limits listed by Urre in that draft. So regarding map limits, I'm pretty sure RMQ could serve as a test case for engine coders, and several of them have kindly expressed interest in supporting it, too. When it comes to oversized maps with badly broken limits made by self-absorbed, criminally negligent outlaw mappers, I guess we are a good example, and a realistic example at that.

QSB 1 should aim to only include stuff that actually, realistically, gets used and can be tested (engine coders can simply get access to our SVN as watchers). In the case of the rotating entity stuff and flickering bmodels, there was already a working collaboration like that.

I think the full list of map related limits ("phat map support") should be part of QSB 1, since this really gets used and I think it isn't too hard to implement. Also, lots of engines support most of that already, anyway - it is in accordance with the 90/10 rule.

I count as part of "phat map support" also an increased map size limit - some of our maps will break the unwritten law of the 4096. Not by much, but they will break it. This means QSB1 will break protocol 666, for example, and it will need its own.



RMQ uses stuff like rotating bmodels, entity alpha, fog, skyboxes and lit files. We're thinking to include stuff like FRIK_FILE and perhaps a few other extensions.

I do think that checkextensions must be in QSB 1, along with things like FRIK_FILE, .lit file/skybox/entity alpha support, rotating bmodel support - including smooth angles (breaks protocol 666 again) -, and also a common QSB_FOG format much as defined here:

http://quakery.quakedev.com/qwiki/index.php/QSB_FOG

and the list of gameplay fixes defined as QSB_GAMEPLAYFIXES:

http://quakery.quakedev.com/qwiki/index ... EPLAYFIXES

as well as the bugfixes mentioned on the wiki page.

All of that is stuff that actually gets used, fixes gameplay bugs, and is widely implemented and working (90/10 rule). We should probably add external texture support to that list, as defined in the QSB wiki entry.

Engines must also contain fixes for flickering (rotating or otherwise) bmodels; mh posted a fix recently. RMQ includes at least one test case for this.

44100 kHz sound support is required by RMQ; this should be standard anyway. Is there an engine that doesn't support this?

If I'm not mistaken, this sums up the stuff that RMQ uses currently or in the near future (like FRIK_FILE). This is as good a starting point as any, and the advantage is that there is a real-world test case with its own (Fitzquake-derived) engine and protocol (999).



A few fixes require protocol changes; for example large map capacity and smooth angles. In a poll on this forum, there was a 14 : 0 vote PRO new network protocol. So let's have it.

Out of necessity, RMQ created its own protocol (999) which right now basically is PROTOCOL_FITZQUAKE (666) with large map support (float coords) and smooth angles (floats again) added on top of it. Protocol 999 should be considered in-development, though; a possibility is to use 777 as a short-term solution (fitz666 + float angles/coords), while 999 is used as a testbed, and an eventual, finished, QSB protocol would be protocol 1000.

Of course there can always be discussion about numbering and general features of both the short-term and long-term solutions. But again, I think the 90/10 rule applies: Let's go with something that exists already, and augment it. Protocol 666 includes most of the required map limits stuff and entity alpha support, it is well commented, and easily extensible.



After QSB 1 is defined and engines start supporting it, more extensions can be added to it; this would be the main point of QSB 2. Protocol changes and refinements would go into protocol 999. At some point after QSB 2 is finished, protocol 1000 is finalized.



The idea of the 90/10 rule (90 % gain for 10 % of the effort), or going with only a small core set that is largely already supported, makes the most sense.

I'd be willing to write down the specs and hopefully transform input from engine coders into a detailed list.

Very basically, QSB1 would include

a) phat map support

b) checkextensions and common map-related extensions

c) a chosen few non-map related extensions, like FRIK_FILE (QSB 2 would focus on more extensions)

d) Protocol 777 (or whatever the number ends up to be - while 999 is used as a testbed, and eventually becomes protocol 1000)

e) bug fixes, gameplay fixes, and 44100 kHz sound support.

Does that sound roughly agreeable?
User avatar
goldenboy
 
Posts: 924
Joined: Fri Sep 05, 2008 11:04 pm
Location: Kiel

Postby Spike » Mon Jul 19, 2010 10:08 am

.
Spike
 
Posts: 2914
Joined: Fri Nov 05, 2004 3:12 am
Location: UK

Postby goldenboy » Mon Jul 19, 2010 3:24 pm

User avatar
goldenboy
 
Posts: 924
Joined: Fri Sep 05, 2008 11:04 pm
Location: Kiel

Postby frag.machine » Mon Jul 19, 2010 4:04 pm

I know FrikaC made a cgi-bin version of the quakec interpreter once and wrote part of his website in QuakeC :) (LordHavoc)
User avatar
frag.machine
 
Posts: 2120
Joined: Sat Nov 25, 2006 1:49 pm

Postby mankrip » Mon Jul 19, 2010 6:43 pm

Ph'nglui mglw'nafh mankrip Hell's end wgah'nagl fhtagn.
==-=-=-=-=-=-=-=-=-=-==
/ /
User avatar
mankrip
 
Posts: 915
Joined: Fri Jul 04, 2008 3:02 am

Postby Spike » Mon Jul 19, 2010 7:09 pm

.
Spike
 
Posts: 2914
Joined: Fri Nov 05, 2004 3:12 am
Location: UK

Postby mankrip » Mon Jul 19, 2010 7:22 pm

:D I know.

However, I feel that any standards should really try to make things uniform. It's a lot easier to implement new features after achieving that, since when making things uniform we can also make them more abstract - including the documentation, which can be a lot easier to understand and write when there's no need to explain things like specific filetype-dependent behavior.
Ph'nglui mglw'nafh mankrip Hell's end wgah'nagl fhtagn.
==-=-=-=-=-=-=-=-=-=-==
/ /
User avatar
mankrip
 
Posts: 915
Joined: Fri Jul 04, 2008 3:02 am

Postby mh » Mon Jul 19, 2010 11:26 pm

User avatar
mh
 
Posts: 2292
Joined: Sat Jan 12, 2008 1:38 am

Postby goldenboy » Tue Jul 20, 2010 2:04 am

User avatar
goldenboy
 
Posts: 924
Joined: Fri Sep 05, 2008 11:04 pm
Location: Kiel

Postby r00k » Tue Jul 20, 2010 3:06 am

r00k
 
Posts: 1111
Joined: Sat Nov 13, 2004 10:39 pm

Postby Baker » Tue Jul 20, 2010 6:54 am

The night is young. How else can I annoy the world before sunsrise? 8) Inquisitive minds want to know ! And if they don't -- well like that ever has stopped me before ..
User avatar
Baker
 
Posts: 3666
Joined: Tue Mar 14, 2006 5:15 am

Postby Baker » Tue Jul 20, 2010 7:23 am

The night is young. How else can I annoy the world before sunsrise? 8) Inquisitive minds want to know ! And if they don't -- well like that ever has stopped me before ..
User avatar
Baker
 
Posts: 3666
Joined: Tue Mar 14, 2006 5:15 am

PreviousNext

Return to General Discussion

Who is online

Users browsing this forum: No registered users and 2 guests