diff options
Diffstat (limited to 'nx-X11/programs/Xserver/hw/nxagent/Options.c')
-rw-r--r-- | nx-X11/programs/Xserver/hw/nxagent/Options.c | 191 |
1 files changed, 191 insertions, 0 deletions
diff --git a/nx-X11/programs/Xserver/hw/nxagent/Options.c b/nx-X11/programs/Xserver/hw/nxagent/Options.c new file mode 100644 index 000000000..5d7855667 --- /dev/null +++ b/nx-X11/programs/Xserver/hw/nxagent/Options.c @@ -0,0 +1,191 @@ +/**************************************************************************/ +/* */ +/* Copyright (c) 2001, 2011 NoMachine, http://www.nomachine.com/. */ +/* */ +/* NXAGENT, NX protocol compression and NX extensions to this software */ +/* are copyright of NoMachine. Redistribution and use of the present */ +/* software is allowed according to terms specified in the file LICENSE */ +/* which comes in the source distribution. */ +/* */ +/* Check http://www.nomachine.com/licensing.html for applicability. */ +/* */ +/* NX and NoMachine are trademarks of Medialogic S.p.A. */ +/* */ +/* All rights reserved. */ +/* */ +/**************************************************************************/ + +#include <stdio.h> +#include <string.h> + +#include "X.h" + +#include "Agent.h" +#include "Args.h" +#include "Options.h" +#include "Utils.h" + +/* + * Instead of having a single options repository + * data could be attached to the display or the + * screen. The macro nxagentOption() should make + * the transition simple. + */ + +AgentOptionsRec nxagentOptions; + +AgentOptionsRec nxagentOptionsBackup; + +AgentOptionsPtr nxagentOptionsPtr = &nxagentOptions; + +/* + * If this is set, print the geometry in the block handler. + */ + +unsigned int nxagentPrintGeometryFlags = 0; +/* + * This must be called at startup to initialize + * the options repository to the default values. + */ + +void nxagentInitOptions() +{ + nxagentOptions.LinkType = UNDEFINED; + + nxagentOptions.Desktop = UNDEFINED; + nxagentOptions.Persistent = 1; + nxagentOptions.Rootless = UNDEFINED; + nxagentOptions.Fullscreen = UNDEFINED; + + nxagentOptions.X = 0; + nxagentOptions.Y = 0; + nxagentOptions.Width = 0; + nxagentOptions.Height = 0; + nxagentOptions.BorderWidth = 0; + + nxagentOptions.WMBorderWidth = -1; + nxagentOptions.WMTitleHeight = -1; + + nxagentOptions.SavedX = 0; + nxagentOptions.SavedY = 0; + nxagentOptions.SavedWidth = 0; + nxagentOptions.SavedHeight = 0; + + nxagentOptions.Timeout = 0; + + nxagentOptions.Nested = 0; + + nxagentOptions.BackingStore = BackingStoreUndefined; + + nxagentOptions.Clipboard = ClipboardBoth; + + nxagentOptions.SharedMemory = 1; + + nxagentOptions.SharedPixmaps = 1; + + nxagentOptions.DeviceControl = 0; + + nxagentOptions.ResetKeyboardAtResume = 1; + + nxagentOptions.Reset = 0; + + nxagentOptions.RootX = 0; + nxagentOptions.RootY = 0; + nxagentOptions.RootWidth = 0; + nxagentOptions.RootHeight = 0; + + nxagentOptions.ViewportXSpan = 0; + nxagentOptions.ViewportYSpan = 0; + + #ifndef __CYGWIN32__ + + nxagentOptions.DesktopResize = 1; + + #else + + nxagentOptions.DesktopResize = 0; + + #endif + + nxagentOptions.Ratio = DONT_SCALE; + nxagentOptions.XRatio = DONT_SCALE; + nxagentOptions.YRatio = DONT_SCALE; + + nxagentOptions.FloatRatio = 1.0; + nxagentOptions.FloatXRatio = 1.0; + nxagentOptions.FloatYRatio = 1.0; + + nxagentOptions.UseDamage = 1; + + nxagentOptions.Binder = UNDEFINED; + nxagentOptions.BinderOptions = NULL; + + nxagentOptions.Xdmcp = 0; + + nxagentOptions.DisplayLatency = 0; + nxagentOptions.DisplayBuffer = UNDEFINED; + nxagentOptions.DisplayCoalescence = 0; + + nxagentOptions.Composite = 1; + + nxagentOptions.IgnoreVisibility = 0; + + nxagentOptions.ViewOnly = 0; + + nxagentOptions.Adaptive = 0; + + nxagentOptions.Streaming = 0; + + nxagentOptions.DeferLevel = UNDEFINED; + nxagentOptions.DeferTimeout = 200; + + nxagentOptions.TileWidth = UNDEFINED; + nxagentOptions.TileHeight = UNDEFINED; + + nxagentOptions.Menu = 1; + + nxagentOptions.ClientOs = UNDEFINED; + + nxagentOptions.InhibitXkb = 1; + + nxagentOptions.CopyBufferSize = COPY_UNLIMITED; +} + +/* + * This is called at session reconnection + * to reset some options to their default + * values. The reason to avoid calling the + * nxagentInitOptions() is that not all the + * options can change value when reconnec- + * ting. + */ + +void nxagentResetOptions() +{ + if (nxagentLockDeferLevel == 0) + { + nxagentOptions.DeferLevel = UNDEFINED; + } + + nxagentOptions.DeferTimeout = 200; + + nxagentOptions.TileWidth = UNDEFINED; + nxagentOptions.TileHeight = UNDEFINED; + + nxagentOptions.WMBorderWidth = -1; + nxagentOptions.WMTitleHeight = -1; +} + +void nxagentSaveOptions() +{ + memcpy(&nxagentOptionsBackup, &nxagentOptions, sizeof(AgentOptionsRec)); +} + +void nxagentRestoreOptions() +{ + nxagentOptions.DeferLevel = nxagentOptionsBackup.DeferLevel; + nxagentOptions.DeferTimeout = nxagentOptionsBackup.DeferTimeout; + + nxagentOptions.TileWidth = nxagentOptionsBackup.TileWidth; + nxagentOptions.TileHeight = nxagentOptionsBackup.TileHeight; +} |