]> git.saurik.com Git - cydia.git/blobdiff - cydo.cpp
Cydia no longer needs its own Substrate Safe Mode.
[cydia.git] / cydo.cpp
index 05327df7257e523673217cc41bd3c99c516d315b..d6e6f7583c79f45acbab1f220371fb6cd89a9560 100644 (file)
--- a/cydo.cpp
+++ b/cydo.cpp
@@ -28,6 +28,8 @@
 
 #include <launch.h>
 
+#include <sys/stat.h>
+
 #include <Menes/Function.h>
 
 typedef Function<void, const char *, launch_data_t> LaunchDataIterator;
@@ -39,12 +41,6 @@ void launch_data_dict_iterate(launch_data_t data, LaunchDataIterator code) {
 }
 
 int main(int argc, char *argv[]) {
-    auto log(fopen("/tmp/cydia.log", "a+"));
-    fprintf(log, "cydo:");
-    for (int arg(1); arg < argc; ++arg)
-        fprintf(log, " %s", argv[arg]);
-    fprintf(log, "\n");
-
     auto request(launch_data_new_string(LAUNCH_KEY_GETJOBS));
     auto response(launch_msg(request));
     launch_data_free(request);
@@ -56,8 +52,14 @@ int main(int argc, char *argv[]) {
 
     auto cydia(false);
 
+    struct stat correct;
+    if (lstat("/Applications/Cydia.app/Cydia", &correct) == -1) {
+        fprintf(stderr, "you have no arms left");
+        return EX_NOPERM;
+    }
+
     launch_data_dict_iterate(response, [=, &cydia](const char *name, launch_data_t value) {
-        if (launch_data_get_type(response) != LAUNCH_DATA_DICTIONARY)
+        if (launch_data_get_type(value) != LAUNCH_DATA_DICTIONARY)
             return;
 
         auto integer(launch_data_dict_lookup(value, LAUNCH_JOBKEY_PID));
@@ -70,7 +72,7 @@ int main(int argc, char *argv[]) {
 
         auto variables(launch_data_dict_lookup(value, LAUNCH_JOBKEY_ENVIRONMENTVARIABLES));
         if (variables != NULL && launch_data_get_type(variables) == LAUNCH_DATA_DICTIONARY) {
-            bool dyld(false);
+            auto dyld(false);
 
             launch_data_dict_iterate(variables, [&dyld](const char *name, launch_data_t value) {
                 if (strncmp(name, "DYLD_", 5) == 0)
@@ -98,18 +100,19 @@ int main(int argc, char *argv[]) {
         if (program == NULL)
             return;
 
-        if (strcmp(program, "/Applications/Cydia.app/Cydia") == 0)
+        struct stat check;
+        if (lstat(program, &check) == -1)
+            return;
+
+        if (correct.st_dev == check.st_dev && correct.st_ino == check.st_ino)
             cydia = true;
     });
 
     if (!cydia) {
-        fprintf(stderr, "thou shalt not pass\n");
+        fprintf(stderr, "none shall pass\n");
         return EX_NOPERM;
     }
 
-    fflush(log);
-    fclose(log);
-
     setuid(0);
     setgid(0);