fteqw/engine/qclib
Spoike 811bce25f1 Too many changes, sorry.
Change revision displays, use the SVN commit date instead of using __DATE__ (when there's no local changes). This should allow reproducible builds.
Added s_al_disable cvar, to block openal and all the various problems people have had with it, without having to name an explicit fallback (which would vary by system).
Add mastervolume cvar (for ss).
Add r_shadows 2 (aka fake shadows - for ss).
Add scr_loadingscreen_aspect -1 setting, to disable levelshots entirely, also disables the progress bar (for ss).
Better support for some effectinfo hacks (for ss).
Added dpcompat_nocsqcwarnings (because of lazy+buggy mods like ss).
Rework the dpcsqc versions of project+unproject builtins for better compat (for ss).
Added dpcompat_csqcinputeventtypes to block unexpected csqc input events (for ss).
Better compat with DP's loadfont console command (for ss).
Added dpcompat_smallerfonts cvar to replicate a DP bug (for ss).
Detect dp's m_draw extension, to work around it (for ss).
Cvar dpcompat_ignoremodificationtimes added. A value of 0 favour the most recently modified file, 1 will use DP-like alphabetically sorted preferences (for ss).
loadfont builtin can now accept outline=1 in the sizes arg for slightly more readable fonts.
Fix bbox calcs for rotated entities, fix needed for r_ignorenetpvs 0.
Hackily parse emoji.json to provide 💩 etc suggestions.
Skip prediction entirely when there's no local entity info. This fixes stair-smoothing in xonotic.
screenshot_cubemap will now capture half-float images when saving to ktx or dds files.
Fix support for xcf files larger than 4gb, mostly to avoid compiler warnings.
Fixed size of gfx/loading.lmp when replacement textures are used.
Added mipmap support for rg8 and l8a8 textures.
r_hdr_framebuffer cvar updated to support format names instead of random negative numbers. Description updated to name some interesting ones.
Perform autoupdate _checks_ ONLY with explicit user confirmation (actual updating already needed user confirmation, but this extra step should reduce the chances of us getting wrongly accused of exfiltrating user data if we're run in a sandbox - we ONLY ever included the updating engine's version in the checks, though there's nothing we can do to avoid sending the user's router's IP).
Removed the 'summon satan all over your harddrive' quit message, in case paranoid security researchers are idiots and don't bother doing actual research.
Removed the triptohell.info and fte.triptohell.info certificates, they really need to stop being self-signed. The updates domain is still self-signed for autoupdates.
Video drivers are now able to report supported video resolutions, visible to menuqc. Currently only works with SDL2 builds.
Added setmousepos builtin. Should work with glx+win32 build.
VF_SKYROOM_CAMERA can now accept an extra two args, setviewprop(VF_SKYROOM_CAMERA, org, axis, degrees).
Removed v_skyroom_origin+v_skyroom_orientation cvars in favour just v_skyroom, which should make it behave more like the 'fog' command (used when csqc isn't overriding).
Added R_EndPolygonRibbon builtin to make it faster+easier to generate textured ribbon/cable/etc wide lines (for TW).
sdl: Fix up sys_sdl.c's file enumeration to support wildcards in directories.
edit command now displays end1.bin/end2.bin correctly, because we can.
Finally add support for f_modified - though ruleset_allow_larger_models and ruleset_allow_overlong_sounds generally make it redundant.
Fix threading race condition in sha1 lookups.
Updated f_ruleset to include the same extra flags reported by ezquake.
A mod's default.fmf file can now contain an eg 'mainconfig config.cfg' line (to explicitly set the main config saved with cfg_save_auto 1 etc).
fmf: basegame steam:GameName/GameDir can be used to try to load a mod directory from an installed steam game. The resulting gamedir will be read-only.
HOMEDIR CHANGE: use homedirs only if the basedir cannot be written or a homedir already exists, which should further reduce the probability of microsoft randomly uploading our data to their cloud (but mostly because its annoying to never know where your data is written).
Fixed buf_cvarlist, should work in xonotic now, and without segfaults.
Added an extra arg to URI_Get_Callback calls - the response size, also changed the tempstring to contain all bytes of the response, you need to be careful about nulls though.
Try to work around nvidia's forced-panning bug on x11 when changing video modes. This might screw with other programs.
sdl: support custom icons.
sdl: support choosing a specific display.
Added some documentation to menuqc builtins.
menusys: use outlines for slightly more readable fonts.
menusys: switch vid_width and vid_height combos into a single video mode combo to set both according to reported video modes.



git-svn-id: https://svn.code.sf.net/p/fteqw/code/trunk@5581 fc73d0e0-1445-4013-8a0c-d673dee63da5
2019-11-20 03:09:50 +00:00
..
dotnet2008 Added MSVC9 (dotnet2008) & MSVC10 (dotnet2010) project files for QCLIB aka FTEQCC 2011-07-16 11:25:56 +00:00
dotnet2010 Added MSVC9 (dotnet2008) & MSVC10 (dotnet2010) project files for QCLIB aka FTEQCC 2011-07-16 11:25:56 +00:00
vc6 Added MSVC9 (dotnet2008) & MSVC10 (dotnet2010) project files for QCLIB aka FTEQCC 2011-07-16 11:25:56 +00:00
byshpuld.ico added qccgui icon (courtesy of shpuld) 2015-12-28 17:41:39 +00:00
cmdlib.h Early version of fteqccgui-qt 2019-01-20 01:00:18 +00:00
comprout.c Early version of fteqccgui-qt 2019-01-20 01:00:18 +00:00
decomp.c Too many changes, sorry. 2019-11-20 03:09:50 +00:00
execloop.h Add explicit skyroom fog. 2019-10-18 08:37:38 +00:00
fteqcc.rc added qccgui icon (courtesy of shpuld) 2015-12-28 17:41:39 +00:00
gui.h Early version of fteqccgui-qt 2019-01-20 01:00:18 +00:00
hash.c Reworked networking a little, separating out common code for separate server/master processes. 2018-12-28 00:04:36 +00:00
hash.h Reworked networking a little, separating out common code for separate server/master processes. 2018-12-28 00:04:36 +00:00
initlib.c Too many changes, sorry. 2019-11-20 03:09:50 +00:00
LICENSE GNU GPL V2 2005-06-01 18:33:06 +00:00
Makefile implemented pm_stepdown. 2018-01-22 19:18:04 +00:00
packager.c Misc compile fixes (mostly warnings) 2019-01-29 20:38:12 +00:00
pr_comp.h Fix qcc crash from stray continue/break/case. Fix warnings from logicops. Recolour error/warning text output on linux. 2018-09-29 03:40:50 +00:00
pr_edict.c Update prediction code to propagate some values properly with certain protocol combinations that I'd overlooked. 2019-09-25 20:23:24 +00:00
pr_exec.c Too many changes, sorry. 2019-11-20 03:09:50 +00:00
pr_multi.c Update prediction code to propagate some values properly with certain protocol combinations that I'd overlooked. 2019-09-25 20:23:24 +00:00
pr_x86.c added cmake file. 2018-03-04 14:41:16 +00:00
progsint.h Update prediction code to propagate some values properly with certain protocol combinations that I'd overlooked. 2019-09-25 20:23:24 +00:00
progslib.h Too many changes, sorry. 2019-11-20 03:09:50 +00:00
progtype.h Rewritten how arguments and fields are stored. No longer mangles types quite so much. 2013-06-02 06:03:54 +00:00
qcc.h Too many changes, sorry. 2019-11-20 03:09:50 +00:00
qcc_cmdlib.c Early version of fteqccgui-qt 2019-01-20 01:00:18 +00:00
qcc_pr_comp.c Fix fteqcc struct args. 2019-09-11 17:35:03 +00:00
qcc_pr_lex.c Too many changes, sorry. 2019-11-20 03:09:50 +00:00
qccgui.c Too many changes, sorry. 2019-11-20 03:09:50 +00:00
qccguiqt.cpp Fix fteqcc struct args. 2019-09-11 17:35:03 +00:00
qccguistuff.c android/msvc tweaks/fixes. 2019-04-19 23:55:47 +00:00
qccmain.c Too many changes, sorry. 2019-11-20 03:09:50 +00:00
qcctui.c Early version of fteqccgui-qt 2019-01-20 01:00:18 +00:00
qcd.h Early version of fteqccgui-qt 2019-01-20 01:00:18 +00:00
qcd_main.c Update prediction code to propagate some values properly with certain protocol combinations that I'd overlooked. 2019-09-25 20:23:24 +00:00
qcdecomp.c remove the old SCVAR macro 2016-09-08 19:04:35 +00:00
readme.txt origional -> original. 2005-07-28 15:52:31 +00:00
test.c revamp fteqcc a little to cope with a.b.c+=f;f++; more correctly/efficiently. 2013-09-26 14:36:52 +00:00

Readme for the FTE QCLib

This library is a library for running QuakeC gamecode. It does not provide any builtins itself.

Features:
	* Multiple library instances, enabling server qc, client qc, and menu qc. There is no maximum instance limit other than memory.

	* Addons, for running multiple progs in any individual instance.

	* Field reassignment, allowing a single engine to support multiple subtly different QC APIs. Also makes additional fields easier.

	* Step-by-step debugging. Requires a text editor of some form, however. A printout of the current line is also useful of course.

	* 64bit support. All strings, globals, and fields are allocated in a consecutive addressable section of memory. This also allows pointers and secure access (not implemented yet, but should be relativly easy bar builtins, which are your responsability).

	* Multiple 'threads'. The library allows a builtin to make a duplicate of the current execution state, or to wipe the current state. This allows sleep commands and fork commands. How handy.

	* Integrated QC compiler. FTEQCC comes as part of qclib. By setting up an interface with a specific value, you can cause it to always run, or run only if it detects a source change.

	* Support for different sorts of progs. Namly Hexen2's, kkqwsv's bigprogs, and FTE's extended format with extra opcodes and possibly fully 32bit offsets. The use of kkqwsv's progs is not recommended - this might be removed at some point.




Quirks:
	* don't use multiple instances of fteqcc at the same time. Compilation will fail.
	* 64bit support requires all strings to be allocated by qclib itself, achivable via a method call. Compatability requires a certain ammount of caution.
	* a fair number of methods are obsolete.
	* An overuse of pointers in the API. There are some macros which you can use to hide some of the dereferences.
	* kkqwsv progs are not reliable. Do not try saving the game. Avoid letting your users know of support.
	
	* Builtin structures are different from original quake. You'll need to convert the arguments to qclib style. This change was required for both multiple instances as well as addon support. It should be straightforward enough.
	* Entity fields are accessed via a pointer from the edict_t structure. This was required to place entity fields within the 64bit accessable section. Changing a . to a -> is not a major issue though. However, there are a lot. do a find and replace of ->v. to ->v->
	* FTE's entities are numbers not pointers. This fact is not made into a big feature as it's kinda incompatable with standard quake. Please do not use numbers directly to refer to ents but instead use the EDICT_TO_PROGS macro which will give protection. This is consistant with standard quake.


Basic usage:
	* refer to test.c for a sample on how to set up the library.
	* refer to progslib.h for the things that I've forgotten to mention.
	* Call the InitProgs function to get a handle to the instance. It takes a parameter which should be set up with some fields. You'll require ReadFile, FileSize, Abort and printf for basic execution.
	* Call the configure function to say how much memory to use, and how many progs/addons to support.
	* Load your progs via LoadProgs. Use a crc of 0 to use any. Otherwise progs will be rejected if it doesn't match. Give it a list of progs-specific builtins too. :)
	* Before calling the spawn builtin, call the InitEnts method. It's parameter stating how many maximum entities to spawn. Using a really large quantity is not much of an issue, as they are allocated as required.
	* Before calling InitEnts, you can tell the VM which fields your engine uses (state all basic ones or none). This will place the entity fields in the same order as your engine expects for entvars_t.
	* Obtain pointers to globals, or just use the globals structure directly.
	* Call the ExecuteProgram method to start execution.
	* Call the FindFunction method to find a function to run in the first place.
	* Call the 'globals' method to retrieve a pointer to the globals (you should always use PR_CURRENT here). Set the parameters with the G_INT/G_FLOAT macros and friends. Use OFS_PARM0 - OFS_PARM7 to set params before calling or read inside a builtin. Use OFS_RETURN to read the return value. These macros are hard coded to use a 'pr_globals' symbol, so avoid renaming builtin parameter names.
	* Ask me on IRC when it all starts keeling over.
	* These are the C files that form qclib: pr_edict.c pr_exec.c pr_multi.c initlib.c qcc_pr_comp.c qcc_pr_lex.c qccmain.c qcc_cmdlib.c comprout.c hash.c qcd_main.c qcdecomp.c