Change implementation of regeneratePkgNI
[platform/core/dotnet/launcher.git] / NativeLauncher / inc / utils.h
index 983eca8..dca091f 100644 (file)
@@ -17,6 +17,7 @@
 #ifndef __UTILS_H__
 #define __UTILS_H__
 
+#include <algorithm>
 #include <string>
 #include <vector>
 #include <functional>
@@ -25,6 +26,8 @@
 
 #include <launcher_env.h>
 
+#include <sys/prctl.h>
+
 #ifndef PATH_SEPARATOR
 #define PATH_SEPARATOR '/'
 #endif
@@ -44,6 +47,10 @@ enum FSFlag : int {
   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
@@ -114,11 +121,11 @@ std::string getMetadataValue(const std::string& pkgId, const std::string& key);
 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
@@ -136,6 +143,13 @@ void splitPath(const std::string& path, std::vector<std::string>& out);
 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
@@ -151,13 +165,6 @@ bool isDirectory(const std::string& path);
 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.
@@ -282,15 +289,60 @@ int pkgmgrGetPkgInfo(const std::string& pkgId, pkgmgrinfo_pkginfo_h* handle);
 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__ */