#ifndef __UTILS_H__
#define __UTILS_H__
+#include <algorithm>
#include <string>
#include <vector>
#include <functional>
#include <launcher_env.h>
+#include <sys/prctl.h>
+
#ifndef PATH_SEPARATOR
#define PATH_SEPARATOR '/'
#endif
FS_PRESERVE_OWNERSHIP_AND_PERMISSIONS = (1 << 3)
};
+#ifndef PR_TASK_PERF_USER_TRACE
+#define PR_TASK_PERF_USER_TRACE 666
+#endif
+
/**
* @brief concat path with PATH_SEPARATOR
* @param[in] destination path
std::string changeExtension(const std::string& path, const std::string& from, const std::string& to);
/**
- * @brief check the package is 'readonly' or not
- * @param[in] package id
+ * @brief check the path is 'readonly' or not
+ * @param[in] path
* @return bool package readonly value
*/
-bool isReadOnlyApp(const std::string& pkgId);
+bool isReadOnlyArea(const std::string& path);
/**
* @brief split path with ":" delimiter and put that in the vector
bool isFile(const std::string& path);
/**
+ * @brief check symlink file
+ * @param[in] source path
+ * @return bool
+ */
+bool isSymlinkFile(const std::string& path);
+
+/**
* @brief check directory exists
* @param[in] source path
* @return bool
bool isManagedAssembly(const std::string& filePath);
/**
- * @brief check the file is native image or not.
- * @param[in] file path
- * @return return true when the file is native image.
- */
-bool isNativeImage(const std::string& filePath);
-
-/**
* @brief Resolve assembly files from directories and append their paths to the given list.
* @remark If a native image exists for an assembly in the same directory, it will be used.
* If multiple assemblies of the same name exist, the first one will be used.
int pkgmgrGetAppInfo(const std::string& appId, pkgmgrinfo_appinfo_h* handle);
/**
- * @brief Executes the metadata filter query for all the installed packages.
+ * @brief Executes the metadata filter query for appinfo.
* This function is a wrapper of pkgmgrinfo_appinfo_metadata_filter_foreach() to handle multi-user case
* @param[in] metadata filter handle
* @param[in] callback function
* @param[in] user data
* @return 0 if success, otherwise -1
*/
-int pkgmgrMDFilterForeach(pkgmgrinfo_appinfo_metadata_filter_h handle,
+int pkgmgrAppMDFilterForeach(pkgmgrinfo_appinfo_metadata_filter_h handle,
pkgmgrinfo_app_list_cb app_cb,
void *user_data);
+/**
+ * @brief Executes the metadata filter query for pkginfo.
+ * This function is a wrapper of pkgmgrinfo_pkginfo_metadata_filter_foreach()
+ * @param[in] metadata filter handle
+ * @param[in] callback function
+ * @param[in] user data
+ * @return 0 if success, otherwise -1
+ */
+int pkgmgrPkgMDFilterForeach(pkgmgrinfo_pkginfo_metadata_filter_h handle,
+ pkgmgrinfo_pkg_list_cb app_cb,
+ void *user_data);
+
+/**
+ * @brief Prints HW Clock log
+ * @param[in] format `printf`-like format string
+ * @param[in] ... `printf`-like variadic list of arguments corresponding to the format string
+ */
+void printHWClockLog(const char* format, ...);
+
+/**
+ * @brief Return NCDB startup hook
+ * @return NCDB startup hook
+ */
+const char* getNCDBStartupHook();
+
+/**
+ * @brief Check is NCDB startup hook provided in DOTNET_STARTUP_HOOKS env
+ * @return `true` if provided, otherwise `false`
+ */
+bool isNCDBStartupHookProvided();
+
+/**
+ * @brief get paths where the resource dll is located in RPK package
+ * @param[in] root path
+ * @return std::string colon-separated string of rpk target paths
+ */
+std::string getResourcePaths(const std::string& rootPath);
+
+/**
+ * @brief check the package is rpk type
+ * @param[in] pkgId package ID
+ * @return return true when package is rpk type
+ */
+bool isRPK(const std::string& pkgId);
+
#endif /* __UTILS_H__ */