tray | SharedPreferences replacement for Android with multiprocess | Runtime Evironment library
kandi X-RAY | tray Summary
kandi X-RAY | tray Summary
If you have read the documentation of the SharedPreferences you might have seen one of these warnings:. Note: This class does not support use across multiple processes. Google even deprecated the multiprocess support because it never worked relieable. Tray is this mentioned explicit cross-process data management approach powered by a ContentProvider. Tray also provides an advanced API which makes it super easy to access and maintain your data with upgrade and migrate mechanisms. Welcome to SharedPreferences 2.0 aka Tray.
Support
Quality
Security
License
Reuse
Top functions reviewed by kandi - BETA
Currently covering the most popular Java, JavaScript and Python libraries. See a Sample of tray
tray Key Features
tray Examples and Code Snippets
const isAbsoluteURL = str => /^[a-z][a-z0-9+.-]*:/.test(str);
isAbsoluteURL('https://google.com'); // true
isAbsoluteURL('ftp://www.myserver.net'); // true
isAbsoluteURL('/foo/bar'); // false
const isAlpha = str => /^[a-zA-Z]*$/.test(str);
isAlpha('sampleInput'); // true
isAlpha('this Will fail'); // false
isAlpha('123'); // false
Community Discussions
Trending Discussions on tray
QUESTION
I have a small warp
server project on Windows that listen to a particular port and do something whenever I send a command to it by REST (for example: POST http://10.10.10.1:5000/print
). It's a small client for printing PDF / receipt directly from another computer.
It works. But my problem is when I had to package
the whole project, the Rust compiler give me an executable file (.exe). The application displays a terminal window when I run it. I want this terminal to be hidden somehow.
I try to run the program as a windows service (by using NSSM). It doesn't work for me since I had to access the printer. Windows doesn't allow my app to access any devices or any other executable as a windows service. (The reasons are explained here: How can I run an EXE program from a Windows Service using C#?)
So I plan to run my app as a tray-icon application so user can control or close the app. (https://github.com/olback/tray-item-rs) Unfortunately, I still cannot hide the app's terminal window.
Another solution that I found is hstart
(https://www.ntwind.com/software/hstart.html). But I would like to use this as "the last resort" solution since many antivirus/windows defender mark it as a malware.
Do anyone know how to hide or get rid of it ?
...ANSWER
Answered 2022-Mar-25 at 00:46Start program in background.
QUESTION
The following code snippet should return the Media Trays available to a printer.
However, with some drivers, specifically Ricoh PCL6 Driver for Universal Print
and HP Universal Printing PCL 6
, in addition to Printer Trays, these drivers also list paper types such as Recycled
, Thick
, Matte
, etc.
From what I can tell, OpenJDK is properly using DC_BINNAMES
when calling DeviceCapabilities
. OpenJDK doesn't even seem to use DC_MEDIATYPENAMES
at all in the source code, so I wouldn't expect e.g. Purple Paper
to even be a queryable property, yet it lists when querying trays from the Ricoh driver.
So what's wrong? Are these PCL 6 drivers just bugged? Is DeviceCapabilities
at fault? Or does the bug live in OpenJDK?
ANSWER
Answered 2022-Mar-25 at 02:01The drivers are bugged. Workarounds exists, but they are complex.
The short:- Match driver name on
Ricoh|HP
andPCL6|PCL 6
- Filter any trayIds > 1000
Some drivers such as HP expose the printer trays properly in other areas, for example:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Print\Printers\\PrinterDriverData
InputSlot
InputSlotDisplayNames
... however this isn't true for drivers such as Ricoh.
After examining a lot of drivers (HP, Ricoh, Xerox, Konica, etc) I've isolated the issue to the following:
- PCL6 drivers
- HP or Ricoh as the vendor
In cases with both vendors, the DC_BINS
value is always > 1000, which is partially explained in the PCL6 MediaSource
specification, quoting:
"... External input trays
1
through248
are selected by substituting the values8
through255
for the enumerated values. Example,8
=first external input tray
,9
=second external input tray
, etc. ..."
Although there's nothing about the 1,000 specifically, and vendors such as Xerox use values over 7000 without the bug. That said, with the problematic vendors, what is observed is that when values are > 1,000 they tend to be actually valid MediaType
values (NOT MediaSource
values), but incremented by 1,000.
Oddly enough, this is very limited to HP and Ricoh and does not apply to other PCL drivers. For example:
- Konica uses trayID of
1000
=LCT
, or "Large Capacity Tray", which is valid. - Xerox offers a PCL6 driver, but commonly uses trayIDs higher than 1000, e.g.
7153
=Tray 1
,7154
=Tray 2
. - Ricoh is known to use trayID of
1025
in the PCL5 version of its driver, which is a valid tray value of1025
=Auto Tray Select
, but this doesn't seem to be the case for their PCL6 driver, which has theMediaType
values mixed in.
So to "fix" this issue, I wrote a series of custom parsing to find out the driver vendor and the tray id.
To locate the trayId from Java:
QUESTION
I'm trying to re-use a regex I'm using to parse another file. This file has some commented rows, and I need to make sure the commented rows aren't captured.
This is the string being parsed:
...ANSWER
Answered 2022-Feb-22 at 04:52Not a robust solution, it does work for the code currently posted but I do not assure this will work with the actual code you might test it on.
The regex expects a single string, hence, when testing this with your file, make sure you're using the -Raw
switch.
See https://regex101.com/r/l0RLPw/2 for details.
QUESTION
Since upgrading to version 2.14.5 of the Cosmos DB emulator, I'm seeing high CPU usage by what appears to be the tray icon process (Microsoft.Azure.Cosmos.Emulator.exe). See below, using up most of a CPU core constantly on an Intel i9-12900K. This was an upgrade from 2.14.4 on Windows 11.
Anyone from the emulator team know what might be going on? Seems like the process is doing something silly, given the system is otherwise quiet and the process is not actually doing anything related to serving requests.
Also worth noting is that opening the "About Azure Cosmos Emulator" dialog immediately drops the CPU usage to 0. When closing the dialog, usage jumps back.
...ANSWER
Answered 2022-Mar-21 at 13:30This appears to have been fixed with release of version 2.14.6
QUESTION
I have a script that runs in the current user space, but in the background, permanently minimized.
It needs to send notifications, via the system tray, or Windows.UI.Notifications mechanism (or something else of this flavor).
How is this done in powershell on Win11/Win10?
...ANSWER
Answered 2022-Mar-16 at 01:28# this can be a manual input array of users as well
$users = ((Get-WMIObject -ClassName Win32_ComputerSystem).Username).Split('\')[1]
$WhatToSend = Read-Host "What do you want the message to be"
foreach ($user in $users){
& msg $user $WhatToSend
}
QUESTION
I have a powershell script that is in my startup:
...ANSWER
Answered 2022-Mar-10 at 18:22Update: The following instructions work as advertised, but you state that you were aware of this approach, and that your only problem was that the styling of File Explorer's GUI in Windows 11 may falsely suggest that the window-style dropdown list (field Run
in a shortcut file's Properties dialog) is disabled.
Here's how to run your script minimized on startup, via the user-specific "$env:APPDATA\Microsoft\Windows\Start Menu\Programs\Startup"
folder.
Move your script file, say
foo.ps1
out of the startup folder,[1] say to your desktop.In its place, create a shortcut file (
.lnk
) that calls your script file with its window minimized:- To do this interactively, via File Explorer's
New > Shortcut
shortcut-menu command:Paste the following target command and submit:
- To do this interactively, via File Explorer's
QUESTION
I have a pandas dataframe containing the following information:
- For each Timestamp, there are a number of Trays (between 1-4) out of 8 available Trays. (So there is a maximum number of 4 Trays per Timestamp.)
- Each Tray consists of 4 positions.
A dataframe could look like this:
...ANSWER
Answered 2021-Sep-15 at 07:32You can create a new dataframe with the timestamp with fixed range of position. Then you merge them together and you will end up with NaN values on errors columns for given missing position. Then you fill the NaN to 1.
Sample code:
QUESTION
I want to recognize the tray is empty or not in the given image using OpenCV in python.
below is what I have tried
- detect the biggest rectangle and cropped by using the below code
ANSWER
Answered 2022-Mar-01 at 20:33I recommend you to:
- do camera calibration to make the lines in your image straight, and
- align your camera well to your production line so you can simplify the image processing and make it more robust, and
- use better illumination conditions if possible.
Given the images above, here is a brute force solution:
- you can first extract the region of interest (ROI) through: HSV segmentation followed by contour detection, then you can extract the rectangular shape of the tray using this SO answer.
QUESTION
QUESTION:
My simple Windows notification application throws an exception with the error message "Access is denied." How can I fix this?
PREFACE:
The structure in use is prescribed by the current implementation of and constraints placed on our application. While a better structure than this may exist, changing the structure is not an option at this time.
Relevant structural information:
We have a service that always runs. This service will spawn a process--let's call it data.exe--for every active session ID on the machine. For example, if there are currently four sessions active on the server with session IDs 1-4, data.exe will be running for all 4 sessions. Notably, the user name in Task Manager for each process is SYSTEM, despite running in non-zero session IDs.
INFORMATION:
My application--toaster.exe--is supposed to be launched from a different process via CreateProcessW()
. The full launch function is adapted from a Raymond Chen blog post found here. As a brief explanation of what this function does, it launches a program with the shell as its parent process. For clarity, I implemented this function into data.exe to launch toaster.exe, and the adaptations I made are simply to handle errors and, obviously, to launch the particular program I want, rather than cmd.exe. Mr. Chen's function was the only method I found that would successfully and reliably launch my application and have it perform as intended.
Currently, if I launch toaster.exe by clicking on it, it performs its functions perfectly. I can also confirm that I am able to launch toaster.exe from another process--I setup a test application that can successfully launch toaster.exe in such a way that it does not throw an exception. To clarify what I mean by "functions perfectly," toaster.exe successfully sends me a simple one-line notification with a message that I have hardcoded for testing purposes.
However, if I launch toaster.exe from a program that was launched by our service, it hits an exception when it attempts to create the winrt::Windows::UI::Notifications::ToastNotification
object. Unfortunately, this last one is the only launch method I care about--this program needs to be compatible with being launched in this way because it will always be launched by data.exe, which, as mentioned in the preface, is launched by our service.
Here is the function in toaster.exe where the exception occurs:
...ANSWER
Answered 2022-Mar-01 at 19:34EDIT 2022/2/28:
I have found a more elegant solution to this problem involving WTSQueryToken()
and GetTokenInformation()
thanks to this SO answer.
WTSQueryToken()
returns a filtered user token, and without any extra steps, this token can be placed into a CreateProcessAsUserW()
call to spawn my notification app.
I opt to call GetTokenInformation()
to obtain the unfiltered (read: elevated) token for the user, which allows me to keep all my application's logs centralized in the Program Files directory. I am unclear if a process launched with an unfiltered token of a user without admin privileges will still be able to log to the Program Files directory, but this is non-essential to the process's ability to run.
SOLUTION:
The error message given for the thrown exception is Access is denied
. This may or may not be the result of a bug related to the PROC_THREAD_ATTRIBUTE_PARENT_PROCESS
flag. The workaround for this is simply to spawn the process again from the child process, using the exact same function call minus the problematic flag.
In my case, I pass a parameter that acts as a flag to tell the child process that it needs to relaunch itself.
EXPLANATION:
Thanks to the guidance of @IInspectable, I was able to resolve my issue.
Firstly, IInspectable informed me that the exception's data type was likely that of a winrt::hresult_error
, which ended up being correct. From this, I was able to see that the exception message was Access is denied
.
After updating my question to reflect this, IInspectable returned to point me towards the bottom of the comments of the Raymond Chen blog post that I linked in my question.
In short, the comment suggests that there is an underlying bug in the API that causes processes spawned in the way demonstrated by Chen to load with incorrect parameters, and offers a simple workaround by using Chen's function from within the child process to launch another child process. The comment also suggests that removing the PROC_THREAD_ATTRIBUTE_PARENT_PROCESS
flag from the second function call is necessary, but this is not something I needed to do for the workaround to succeed.
For posterity, the comment from the blog post comments is as follows:
There are issues using the PROC_THREAD_ATTRIBUTE_PARENT_PROCESS flag… Environment variables for the new process are copied from the High-IL process not the Medium-IL process which cause issues with shell functions and some directory paths (%temp%, %userprofile% etc…) The token security descriptor for the process is also created without an ACE for the current user blocking access to most resources and the token security descriptor will also have a High-IL even though the process itself has a Medium-IL… This blocks the new process from accessing any system objects (events/pipes/sections/IPC etc…) while also blocking the process from opening its own process token with TOKEN_QUERY access. This seems to be a severe bug with the API but not sure if it’ll be fixed. As a workaround you can call CreateProcess a second time but from the new child process (without the PARENT_PROCESS flag) and it’ll be created with the correct token DAC security and environment variables (this is also why the above above sample doesn’t have issues with cmd.exe since it launches child processes).
QUESTION
I'm using docker-compose
to launch a commandbox lucee container and a mysql contianer.
I'd like to change the web root of the lucee server, to keep all my non-public files hidden (server.json etc, cfmigrations resources folder)
I've followed the docs and updated my server.json
https://commandbox.ortusbooks.com/embedded-server/server.json/packaging-your-server
ANSWER
Answered 2022-Feb-24 at 15:19You're using a pre-warmed image
Community Discussions, Code Snippets contain sources that include Stack Exchange Network
Vulnerabilities
No vulnerabilities reported
Install tray
Support
Reuse Trending Solutions
Find, review, and download reusable Libraries, Code Snippets, Cloud APIs from over 650 million Knowledge Items
Find more librariesStay Updated
Subscribe to our newsletter for trending solutions and developer bootcamps
Share this Page